조회 수 1221 추천 수 1 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
Extra Form
라이선스 기타(따로 작성)

안녕하세요?

 

여러모로 부족한 실력이지만 파이썬을 이용하여 그누보드의 백엔드를 보완하는 프로젝트를 시도해보려고 하네요 ^^

 

그 첫번째 단계로 파이썬으로 구현한 그누보드 자동 글쓰기 함수를 작성해봤어요.

 

저는 크롤링 서버를 별도로 두고 있기 때문에, 외부에서 그누보드 DB에 접속하는 방식으로 구현했어요.

(사용하시는 웹호스팅 또는 VPS에서 DB 외부접속을 허용하도록 설정해야 합니다.)

 

아미나 & 파이썬 3.7에서 테스트했으나, 그누보드 및 파이썬의 다른 버전에서도 대동소이할 것 같네요 :)

 

import pymysql
from datetime import datetime


def board_write(board, subject, content, mb_id, nickname):
    # MySQL connection 및 cursor를 생성합니다.
    conn = pymysql.connect(host = 'URL을입력하세요', 
                           user = 'DB계정을입력하세요', 
                           password = 'DB비번을입력하세요',
                           db = 'DB명을 입력하세요', 
                           charset = 'utf8')
    curs = conn.cursor()

    # wr_num을 구한 후 작성글을 INSERT 합니다.
    sql = f"select wr_num from g5_write_{board}"
    curs.execute(sql)
    wr_num = str(int(curs.fetchone()[0]) - 1)
    now = datetime.today().strftime('%Y-%m-%d %H:%M:%S') # 그누보드의 날짜 형식 준수 (ex: 2021-04-05 23:45:15)
    sql = f"insert into g5_write_{board} set wr_num = {wr_num}, \
          wr_reply = '', wr_comment = 0, ca_name = '', wr_option = 'html1', wr_subject = '{subject}', \
          wr_content = '{content}', wr_link1 = '', wr_link2 = '', \
          wr_link1_hit = 0, wr_link2_hit = 0, wr_hit = 1, wr_good = 0, wr_nogood = 0, \
          mb_id = '{mb_id}', wr_password = '', wr_name = '{nickname}', wr_email = '', wr_homepage = '', \
          wr_datetime = '{now}', wr_last = '{now}', wr_ip = '111.111.111.111', \
          wr_1 = '', wr_2 = '', wr_3 = '', wr_4 = '', wr_5 = '', \
          wr_6 = '', wr_7 = '', wr_8 = '', wr_9 = '', wr_10 = '', \
          wr_comment_reply = '', wr_facebook_user = '', wr_twitter_user = '', \
          as_re_name = '', as_tag = '', as_map = '', as_icon = '', as_thumb = '', as_video = ''"
    curs.execute(sql)

    # wr_id를 구한 후 부모 아이디에 UPDATE 합니다.
    sql = f"select wr_id from g5_write_{board}"
    curs.execute(sql)
    wr_id = str(curs.fetchall()[-1][0])
    sql = f"update g5_write_{board} set wr_parent = {wr_id} where wr_id = {wr_id}"
    curs.execute(sql)

    # 새 글을 INSERT 합니다.
    sql = f"insert into g5_board_new ( bo_table, wr_id, wr_parent, bn_datetime, mb_id ) values \
          ( '{board}', '{wr_id}', '{wr_id}', '{now}', '{mb_id}' )"
    curs.execute(sql)

    # 게시글을 1 증가시킵니다.
    sql = f"select bo_count_write from g5_board where bo_table = '{board}'"
    curs.execute(sql)
    bo_count_write = str(int(curs.fetchone()[0]))
    sql = f"update g5_board set bo_count_write = {bo_count_write} + 1 where bo_table = '{board}'"
    curs.execute(sql)

    # MySQL connection 닫기
    conn.close()
    return


board = '게시판명을입력하세요'
subject = '제목을입력하세요'
content = '내용을입력하세요(HTML태그도가능합니다)'
mb_id = 'ID를입력하세요'
nickname = '작성자명을입력하세요'
board_write(board, subject, content, mb_id, nickname)

 

 

위 소스를 이용하여 테스트한 결과를 캡쳐하여 첨부합니다 ^^

 

img 20210408 194713.png.jpg

 

 

SQL 문만 놓고보면 그누보드의 write_update.php와 크게 다르지 않지만,

 

파이썬으로 외부 접속을 하면 PHP의 global $g5 등을 사용할 수 없기 때문에 다소의 차이가 있습니다.

 

그리고 wr_hit을 0으로 지정하면 크롤링 후 등록한 글의 조회수가 0으로 처리되기 때문에, 의도적으로 1로 설정했어요 ^^

 

참고로 이는 DB를 직접 건드리지 않고 requests를 이용하여 POST 전송으로 글을 작성한 경우에도 마찬가지로 발생하는 문제이며,

 

이 경우에는 requests로 다시 한 번 hit을 하는 방식으로 해결하여야 합니다.

 

 

한편 위 소스는 SQL injection과 관련하여 보완해야 될 부분이 있을 것 같네요 ㅠㅠ

 

마지막으로 작성자명을 실제 계정의 닉네임과 달리 적용한 경우에는, 

 

위 함수로 글을 올린 후에 로그인하여 글을 수정하면 실제 계정의 닉네임으로 변경되는 점을 주의하셔야 됩니다!

 

 

제가 앞으로 시간이 있을 때 파이썬으로 첨부파일까지 업로드할 수 있도록 위 소스를 보완해볼게요~

 

허접한 소스를 읽어주셔서 감사드리고 그럼 다들 편안한 저녁 되세요 ^^

 

  • profile
    이니스프리 2021.09.10 21:16
    업데이트된 버전을 올렸습니다 ^-^
    https://studyforus.com/study/818104

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
23 코드 [Python/Telegram] Studyforus 알림봇 (댓글, 스티커 파싱) 7 file 이니스프리 2020.05.15 648
» 코드 [Python-Gnuboard] 파이썬으로 구현한 그누보드 자동 글쓰기 함수 1 file 이니스프리 2021.04.08 1221
21 코드 [PyQt] sir.kr에서 스크랩한 게시글을 보여주는 윈도우앱 (검색 및 정렬 가능) 7 file 이니스프리 2019.08.09 999
20 코드 [PHP] 이미지를 원하는 크기(원본비율 유지)로 리사이즈 하여 출력 (원본 이미지는 수정하지 않습니다) 6 이니스프리 2018.12.20 7710
19 코드 [PHP] 기상청 중기예보를 캐러셀로 보여주는 위젯 (매우 허접합니다 ㅠㅠ) 10 file 이니스프리 2018.09.28 647
18 코드 [PHP] 기상청 RSS 시간별 예보 위젯 - cache 적용(?) 9 file 이니스프리 2018.10.28 850
17 코드 [PHP] 그누보드 자동 게시글 작성 - 일본기상협회의 우리나라 날씨를 크롤링한 후 파파고로 번역하여 글 작성 4 file 이니스프리 2018.11.15 657
16 코드 [PHP] 간단한 캐싱 클래스 3 title: 황금 서버 (30일)humit 2018.12.06 605
15 코드 [PHP/Javascript] 아미나에 자동으로 게시글을 생성하고 Ajax로 전송하여 결과를 표시하기 2 file 이니스프리 2019.07.09 776
14 코드 [JS]클라이언트에서 Ip를 얻어보자 2 Hanam09 2019.01.21 625
13 코드 [JS] 클라이언트단 GET Parameter Hanam09 2019.11.16 466
12 코드 [JS] http를 https로 리디렉션! 3 Hanam09 2018.12.30 674
11 코드 Koa에서 자동으로 라우팅 채워주기 Seia 2020.01.22 437
10 코드 JavaScript에서 파이썬 문자열 처리 함수 중 하나 (바인딩)를 구현 7 Seia 2020.01.20 463
9 코드 html 초보가 만든 자소서 4 title: 대한민국 국기gimmepoint 2018.04.21 651
8 코드 HEX를 RGB로, RGB를 HEX로 바꾸는 PHP 코드 1 네모 2018.05.05 507
7 코드 Hello, World!를 출력해보자 18 네모 2018.04.21 568
6 코드 Git 저장소에서 자동으로 받아 업데이트하는 쉘 스크립트 5 NoYeah 2017.09.16 650
5 코드 C언어 삼중자를 이용한 코드 title: 황금 서버 (30일)humit 2018.07.22 410
4 코드 CMD로 로컬 연결 고정 IP 설정하기 1 title: 황금 서버 (30일)humit 2018.02.06 1038
Board Pagination Prev 1 2 3 4 Next
/ 4