<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ko">
	<id>https://devcafe.co.kr/w/index.php?action=history&amp;feed=atom&amp;title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95</id>
	<title>파이썬 postgresql flask json 설치법 - 편집 역사</title>
	<link rel="self" type="application/atom+xml" href="https://devcafe.co.kr/w/index.php?action=history&amp;feed=atom&amp;title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95"/>
	<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95&amp;action=history"/>
	<updated>2026-05-19T19:57:14Z</updated>
	<subtitle>이 문서의 편집 역사</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95&amp;diff=1394&amp;oldid=prev</id>
		<title>2025년 5월 19일 (월) 21:54에 Devcafe님의 편집</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95&amp;diff=1394&amp;oldid=prev"/>
		<updated>2025-05-19T21:54:35Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 5월 20일 (화) 06:54 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l103&quot;&gt;103번째 줄:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;103번째 줄:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;4. **다중 환경 지원**을 위해 위와 같이 `development`, `test`, `production` 프로필을 분리하는 것이 좋습니다.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;4. **다중 환경 지원**을 위해 위와 같이 `development`, `test`, `production` 프로필을 분리하는 것이 좋습니다.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[category:python]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95&amp;diff=1277&amp;oldid=prev</id>
		<title>Devcafe: 새 문서: * 아래는 PostgreSQL 데이터베이스 연결 정보를 JSON 파일로 저장하는 예제입니다. * 보안을 위해 중요한 정보는 직접 공유하지 마시고, 필요시 `.gitignore`에 추가하여 버전 관리에서 제외하세요.  === db_config.json === &lt;source lang=python&gt; {   &quot;development&quot;: {     &quot;host&quot;: &quot;localhost&quot;,     &quot;port&quot;: 5432,     &quot;database&quot;: &quot;myflaskapp_dev&quot;,     &quot;user&quot;: &quot;postgres&quot;,     &quot;password&quot;: &quot;devpassword123&quot;,     &quot;schema&quot;: &quot;public&quot;   },   &quot;t...</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_postgresql_flask_json_%EC%84%A4%EC%B9%98%EB%B2%95&amp;diff=1277&amp;oldid=prev"/>
		<updated>2025-04-25T16:12:04Z</updated>

		<summary type="html">&lt;p&gt;새 문서: * 아래는 PostgreSQL 데이터베이스 연결 정보를 JSON 파일로 저장하는 예제입니다. * 보안을 위해 중요한 정보는 직접 공유하지 마시고, 필요시 `.gitignore`에 추가하여 버전 관리에서 제외하세요.  === db_config.json === &amp;lt;source lang=python&amp;gt; {   &amp;quot;development&amp;quot;: {     &amp;quot;host&amp;quot;: &amp;quot;localhost&amp;quot;,     &amp;quot;port&amp;quot;: 5432,     &amp;quot;database&amp;quot;: &amp;quot;myflaskapp_dev&amp;quot;,     &amp;quot;user&amp;quot;: &amp;quot;postgres&amp;quot;,     &amp;quot;password&amp;quot;: &amp;quot;devpassword123&amp;quot;,     &amp;quot;schema&amp;quot;: &amp;quot;public&amp;quot;   },   &amp;quot;t...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;새 문서&lt;/b&gt;&lt;/p&gt;&lt;div&gt;* 아래는 PostgreSQL 데이터베이스 연결 정보를 JSON 파일로 저장하는 예제입니다.&lt;br /&gt;
* 보안을 위해 중요한 정보는 직접 공유하지 마시고, 필요시 `.gitignore`에 추가하여 버전 관리에서 제외하세요.&lt;br /&gt;
&lt;br /&gt;
=== db_config.json ===&lt;br /&gt;
&amp;lt;source lang=python&amp;gt;&lt;br /&gt;
{&lt;br /&gt;
  &amp;quot;development&amp;quot;: {&lt;br /&gt;
    &amp;quot;host&amp;quot;: &amp;quot;localhost&amp;quot;,&lt;br /&gt;
    &amp;quot;port&amp;quot;: 5432,&lt;br /&gt;
    &amp;quot;database&amp;quot;: &amp;quot;myflaskapp_dev&amp;quot;,&lt;br /&gt;
    &amp;quot;user&amp;quot;: &amp;quot;postgres&amp;quot;,&lt;br /&gt;
    &amp;quot;password&amp;quot;: &amp;quot;devpassword123&amp;quot;,&lt;br /&gt;
    &amp;quot;schema&amp;quot;: &amp;quot;public&amp;quot;&lt;br /&gt;
  },&lt;br /&gt;
  &amp;quot;test&amp;quot;: {&lt;br /&gt;
    &amp;quot;host&amp;quot;: &amp;quot;localhost&amp;quot;,&lt;br /&gt;
    &amp;quot;port&amp;quot;: 5432,&lt;br /&gt;
    &amp;quot;database&amp;quot;: &amp;quot;myflaskapp_test&amp;quot;,&lt;br /&gt;
    &amp;quot;user&amp;quot;: &amp;quot;postgres&amp;quot;,&lt;br /&gt;
    &amp;quot;password&amp;quot;: &amp;quot;testpassword123&amp;quot;,&lt;br /&gt;
    &amp;quot;schema&amp;quot;: &amp;quot;public&amp;quot;&lt;br /&gt;
  },&lt;br /&gt;
  &amp;quot;production&amp;quot;: {&lt;br /&gt;
    &amp;quot;host&amp;quot;: &amp;quot;db.production.com&amp;quot;,&lt;br /&gt;
    &amp;quot;port&amp;quot;: 5432,&lt;br /&gt;
    &amp;quot;database&amp;quot;: &amp;quot;myflaskapp_prod&amp;quot;,&lt;br /&gt;
    &amp;quot;user&amp;quot;: &amp;quot;prod_user&amp;quot;,&lt;br /&gt;
    &amp;quot;password&amp;quot;: &amp;quot;prodpassword456&amp;quot;,&lt;br /&gt;
    &amp;quot;schema&amp;quot;: &amp;quot;app_schema&amp;quot;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Flask에서 사용하는 방법 ===&lt;br /&gt;
&amp;lt;source lang=python&amp;gt;&lt;br /&gt;
import json&lt;br /&gt;
import psycopg2&lt;br /&gt;
from flask import Flask&lt;br /&gt;
&lt;br /&gt;
app = Flask(__name__)&lt;br /&gt;
&lt;br /&gt;
# JSON 파일에서 설정 로드&lt;br /&gt;
def load_db_config(env=&amp;#039;development&amp;#039;):&lt;br /&gt;
    with open(&amp;#039;db_config.json&amp;#039;) as f:&lt;br /&gt;
        config = json.load(f)&lt;br /&gt;
    return config.get(env, config[&amp;#039;development&amp;#039;])&lt;br /&gt;
&lt;br /&gt;
@app.route(&amp;#039;/&amp;#039;)&lt;br /&gt;
def test_connection():&lt;br /&gt;
    db_config = load_db_config()&lt;br /&gt;
    &lt;br /&gt;
    try:&lt;br /&gt;
        conn = psycopg2.connect(&lt;br /&gt;
            host=db_config[&amp;#039;host&amp;#039;],&lt;br /&gt;
            port=db_config[&amp;#039;port&amp;#039;],&lt;br /&gt;
            database=db_config[&amp;#039;database&amp;#039;],&lt;br /&gt;
            user=db_config[&amp;#039;user&amp;#039;],&lt;br /&gt;
            password=db_config[&amp;#039;password&amp;#039;]&lt;br /&gt;
        )&lt;br /&gt;
        cur = conn.cursor()&lt;br /&gt;
        cur.execute(&amp;quot;SELECT version();&amp;quot;)&lt;br /&gt;
        version = cur.fetchone()[0]&lt;br /&gt;
        cur.close()&lt;br /&gt;
        conn.close()&lt;br /&gt;
        return f&amp;quot;Connected to PostgreSQL: {version}&amp;quot;&lt;br /&gt;
    except Exception as e:&lt;br /&gt;
        return f&amp;quot;Connection failed: {str(e)}&amp;quot;&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;#039;__main__&amp;#039;:&lt;br /&gt;
    app.run(debug=True)&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* 보안 강화를 위한 추가 권장 사항&lt;br /&gt;
&lt;br /&gt;
1. **환경 변수 사용** (더 안전한 방법):&lt;br /&gt;
&amp;lt;source lang=python&amp;gt;&lt;br /&gt;
   import os&lt;br /&gt;
   from dotenv import load_dotenv&lt;br /&gt;
&lt;br /&gt;
   load_dotenv()  # .env 파일에서 환경 변수 로드&lt;br /&gt;
&lt;br /&gt;
   db_config = {&lt;br /&gt;
       &amp;#039;host&amp;#039;: os.getenv(&amp;#039;DB_HOST&amp;#039;),&lt;br /&gt;
       &amp;#039;password&amp;#039;: os.getenv(&amp;#039;DB_PASSWORD&amp;#039;)&lt;br /&gt;
       # ...&lt;br /&gt;
   }&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
2. `.gitignore`에 추가:&lt;br /&gt;
&amp;lt;source lang=python&amp;gt;&lt;br /&gt;
   db_config.json&lt;br /&gt;
   .env&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
3. **권한 설정**:&lt;br /&gt;
&amp;lt;source lang=bash&amp;gt;&lt;br /&gt;
   chmod 600 db_config.json  # 소유자만 읽기/쓰기 가능&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
4. **다중 환경 지원**을 위해 위와 같이 `development`, `test`, `production` 프로필을 분리하는 것이 좋습니다.&lt;/div&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
</feed>