1. config.ini 만들기 

  2. 실행파일 가져가기

  3. 실행 테스트

변경개발시          : 파이썬 3.x , paramiko , ConfigParser, pyinstaller 설치

ini 수정 수 사용시 : ini 수정만 함, 서버스크립 작성 (1.2), tomcat war root 위치 설정확인

was : tomcat 8.5


1. 소스들

 1.1 ini 파일 생성 ( 예제 )

from configparser import ConfigParser
config = ConfigParser()
config['settings'] = {
'go': 'set -m; /home/tomcat/apache-tomcat-8.5.53/bin/startup.sh',
'stop': '/home/tomcat/apache-tomcat-8.5.53/bin/shutdown.sh',
'waslog': 'tail -f /home/tomcat/apache-tomcat-8.5.53/logs/catalina.out',
'rebilud': '/home/tomcat/bt.sh'
}

config['ssh'] = {
'id': 'root',
'pw': 'pw',
'host': '192.168.0.8',
'port': '22'
}

config['files'] = {
'upfile': 'C:/Users/torrms/Desktop/web.war',
'dwfile': '/home/tomcat/web.war'
}
with open('./config.ini', 'w') as f:
config.write(f)

 예파일  config.ini

[settings]
go = set -m; /home/tomcat/apache-tomcat-8.5.53/bin/startup.sh
stop = /home/tomcat/apache-tomcat-8.5.53/bin/shutdown.sh
waslog = tail -f /home/tomcat/apache-tomcat-8.5.53/logs/catalina.out
rebilud = /home/tomcat/bt.sh

[ssh]
id = root
pw = pw
host = 198.168.0.8
port = 22

[files]
upfile = C:/Users/torrms/Desktop/web.war
dwfile = /home/tomcat/web.war

 

 1.2  rebilud 를 위한 sh 생성 예

 - 직접 서버에서 실행권한 및 스크립트를 작성한다. 

 - war 반영 위치를 tomcat 에 설정한다. 또는 위치 확인

 - 경로는 반드시 full 경로 사용 .. 등의 사용은 안됨.

 -  예)

  > vi bt.sh

rm -rf web
mkdir web
cd web
jar xvf /home/tomcat/web.war
cd /home/tomcat
mv web.war ./bakwar/wab_20$(date +%Y%m%d_%H%M%S).war

 

 2. 실행파일 (첨부 확인) 또는 소스 (접는글 참조, 단 들여쓰기가 날라가네요 ^^)

더보기

#실행용으로 변경시 확인하세요 ^^

import paramiko
import os, sys
from configparser import ConfigParser

# ssh 명령을 수행한다.
# exit status를 리턴한다.
def ssh_execute(ssh, command, is_print=True):
# ssh 명령의 결과로 exit status를 구하는게 쉽지 않다.
# 따라서, 명령의 끝에 "mark=$?"를 출력하여,
# 최종 exit statud를 구할 수 있도록 한다.
exit_status=0
mark="ssh_helper_result_mark!!@@="
command=command+";echo " + mark + "$?"

try:
stdin, stdout, stderr = ssh.exec_command(command, get_pty=True)
except Exception as e:
print(e)
raise e

for line in stdout:
msg=line.strip('\n')
if (msg.startswith(mark)):
exit_status=msg[len(mark):]
else:
if (True == is_print):
print(line.strip('\n'))

return int(exit_status)

# sftp 상에 경로를 생성한다.
# remote 경로가 directory이면, is_dir에 True를 전달한다.
def mkdir_p(sftp, remote, is_dir=False):
dirs_ = []
if is_dir:
dir_ = remote
else:
dir_, basename = os.path.split(remote)
while len(dir_) > 1:
dirs_.append(dir_)
dir_, _ = os.path.split(dir_)

if len(dir_) == 1 and not dir_.startswith("/"):
dirs_.append(dir_) # For a remote path like y/x.txt

while len(dirs_):
dir_ = dirs_.pop()
try:
sftp.stat(dir_)
except:
print("making ... dir", dir_)
sftp.mkdir(dir_)

#https://greenfishblog.tistory.com/258
# sftp 상에 파일을 업로드한다.
# src_path에 dest_path로 업로드한다. 두개 모두 file full path여야 한다.
def file_upload(sftp, src_path, dest_path):
#mkdir_p(sftp, dest_path)
try:
sftp.put(src_path, dest_path)
except Exception as e:
print("fail to upload " + src_path + " ==> " + dest_path)
raise e
print("success to upload " + src_path + " ==> " + dest_path)
return "0"

def get_sftp(ssh):
try:
sftp = paramiko.SFTPClient.from_transport(ssh.get_transport())
except Exception as e:
print(e)
raise e
return sftp


def get_ssh(host_ip, port, id, pw):
try:
# ssh client 생성
ssh = paramiko.SSHClient()

# ssh 정책 설정
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

# connect
ssh.connect(hostname=host_ip, port=port, username=id, password=pw)
except Exception as e:
print(e)
raise e

return ssh

# 프로세스 시작 ##################################
if __name__ == '__main__':
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

parser = ConfigParser()
parser.read('config.ini')

print(parser.sections())

ip = parser.get('ssh', 'host')
port = parser.get('ssh', 'port')
id = parser.get('ssh', 'id')
pwd = parser.get('ssh', 'pw')

ssh.connect(ip,port=port, username=id, password=pwd)

# 웹서버 명령
#exitcode = ssh_execute(ssh, "cat /project/EDIP/edip.sh")
#print("result : %d" % exitcode)
go = parser.get('settings', 'go')
stop = parser.get('settings', 'stop')
waslog = parser.get('settings', 'waslog')
rebilud = parser.get('settings', 'rebilud')

#자신의 반영 파일 로컬위치
upfile = parser.get('files', 'upfile')
dwfile = parser.get('files', 'dwfile')

print(go , stop, waslog, rebilud, upfile, dwfile)

print(os.path.exists(upfile))
if os.path.exists(upfile):
print(str(os.path.getsize(upfile)/1024/1024) + " MB")
else:
print("파일이 " + upfile + "존재 하지 않습니다.")
sys.exit()

#
#https://greenfishblog.tistory.com/258

# 정지
a = ssh_execute(ssh, stop)
while True:
if a == 0:
print("정지 : %d" % a)
break

#파일 업로드

sftp = get_sftp(ssh)
res = file_upload(sftp, upfile, dwfile)
while True:
if res == "0":
print("파일업로드 : %s" % res)
break



#반영
a = ssh_execute(ssh, rebilud)
while True:
if a == 0:
print("반영 : %d" % a)
break

#재시작
a = ssh_execute(ssh, go)
while True:
if a == 0:
print("재시작 : %d" % a)
break

#로그확인
a = ssh_execute(ssh, waslog)
while True:
if a == 0:
print("result : %d" % a)
break

ssh.close()
sftp.close()

 

autorebuild.zip
8.61MB

 

3. 실행 테스트

dos 창이 뜨면서 실행 및 등등의 작업이 진행됨을 알수 있다.

 

rabbitMQ server 설치 및 플러그인 화면 확인

 

CentsOS 7.x

* 서버는 무조건 알랭을 설치 (erlang)

 

참고

https://marshallslee.tistory.com/entry/CentOS-7%EC%97%90-RabbitMQ-%EC%84%A4%EC%B9%98%ED%95%98%EA%B8%B0

https://babtingdev.tistory.com/340

 

1. 패키지 업데이트

yum install epel-release

yum update

reboot

 

2. erlang 설치

wget http://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm

rpm -Uvh erlang-solutions-1.0-1.noarch.rpm

yum install erlang

 

 

3. 설치 패키지 확인

https://packagecloud.io/rabbitmq/rabbitmq-server/

rpm -Uvh https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.7.12/rabbitmq-server-3.7.12-1.el7.noarch.rpm

 

rpm -Uvh https://packagecloud.io/rabbitmq/rabbitmq-server/packages/el/7/rabbitmq-server-3.7.23-1.el7.noarch.rpm

  • 최신

rpm -Uvh https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.2/rabbitmq-server-3.8.2-1.el7.noarch.rpm

 

  • 경고 잡기

[root@localhost ~]# rpm --import https://packagecloud.io/rabbitmq/rabbitmq-server/gpgkey

[root@localhost ~]# rpm --import https://packagecloud.io/gpg.key

[root@localhost ~]# rpm --import https://github.com/rabbitmq/signing-keys/releases/download/2.0/rabbitmq-release-signing-key.asc

[root@localhost ~]# rpm -Uvh https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.8.2/rabbitmq-server-3.8.2-1.el7.noarch.rpm

 

  • 설치 에러 확인

Failed dependencies:

        socat is needed by rabbitmq-server-3.8.2-1.el7.noarch

    rabbitMq를 설치하는데 socat이 필요하다고 에러가 나는 경우 socat 설치

yum install socat

 

4. 모니터링 플러그인

rabbitmq-plugins enable rabbitmq_management

chown -R rabbitmq:rabbitmq /var/lib/rabbitmq/

 

5. 방화벽

firewall-cmd --permanent --zone=public --add-port=4369/tcp

firewall-cmd --permanent --zone=public --add-port=5671/tcp

firewall-cmd --permanent --zone=public --add-port=5672/tcp

firewall-cmd --permanent --zone=public --add-port=15672/tcp

firewall-cmd --permanent --zone=public --add-port=25672/tcp

firewall-cmd --permanent --zone=public --add-port=61613/tcp

firewall-cmd --permanent --zone=public --add-port=61614/tcp

firewall-cmd --permanent --zone=public --add-port=1883/tcp

firewall-cmd --permanent --zone=public --add-port=8883/tcp

 

firewall-cmd --reload

 

6-1. 서비스 등록

systemctl enable rabbitmq-server

 

6-2. 서비스 시작

systemctl start rabbitmq-server

 

7. 사용자 등록

 

계정 추가 (admin 계정 test/test 계정

rabbitmqctl add_user 계정 패스워드

rabbitmqctl add_user admin 1234

 

계정을 관리자로 등록

rabbitmqctl set_user_tags 계정 administrator

rabbitmqctl set_user_tags admin administrator

 

권한 설정

rabbitmqctl set_permissions -p / 계정".*" ".*" ".*"

rabbitmqctl set_permissions -p / admin ".*" ".*" ".*"

 

8. 상태확인

rabbitmqctl status

 

systemctl restart rabbitmq-server

 

- 화면확인

http://192.168.5.114:15672/

 

 

9. 운영

 

  •  설정

https://www.rabbitmq.com/configure.html 

https://www.rabbitmq.com/configure.html#config-file-formats

 

중요 설정

RabbitMQ가 데이터를 저장하는 파티션의 디스크 여유 공간 제한.

heartbeat = 60

 

 

도커에 RabbitMQ 서버를 올려 보도록 해보자!!

 

쿠바네티스 화면에서 이미 레빗 MQ가 있으므로 오피셜로 가보도록 한다.

생성되었으면 알아서 포트랑 들어가 있다.!!

중요 포트는 AMQP 사용을 위한 32789 [기본:5672] 와 웹 매니터를 위한 포트 기본:15672


1.추가설정

 - 매니저 설치

 - AMQP1.0 지원

 직접 명령을 해줘야 하기 때문에 내부 콘솔로 들어 갑니다.

들어가서 프른화면을 봅니다.

명령어를 입력하여 플러그인을 설치 합니다.

플러그인 설치후 상태확인도 살포시 해봅니다.

 

 

 

 

매니저 플러그 인

rabbitmq-plugins enable rabbitmq_management

 

AMQP1.0


rabbitmq-plugins enable rabbitmq amqp_1_0

 

설치 완료 되고 조금 기다려면 알아서 재기동

상태확인을 해 봅니다.

rabbitmqctl status

이렇게 볼수 있습니다.

 

그러면

http://localhost:15672 접속해 봅니다. 기본설정 로컬해당 (guest/guest)

자, 이제 시작 입니다.  두둥

'개발하기 > 도커_관련' 카테고리의 다른 글

도커에서 kitematic 사용 문제점 - 진행중  (0) 2019.08.22
도커 사용기  (0) 2019.08.13

지도 표기 사이트들


윈디


어스널

 

 

이전글 : 네이버 뉴스 RSS 읽어 오기 -1-

 

네이버 뉴스 RSS 읽어 오기 -1-

개인 목적으로 RSS 읽어오는 것은 불법이 아니지만 홈페이지나 개인 블로그에 개재하는 것은 불법 및 저작권 위반일수 있으니 이는 확인 하시기 바랍니다. jsp 자바 웹서비스에서 RSS 읽어 보여주는 테스트를 진행..

torrms.tistory.com

 

먼저, 메이븐이나 다른 라이브러리는 읽지 않아도 되었지만, 혹여 컴파일이 안되시는 경우가 있을 수 있으니

import  부분을 잘 참고 하시기 바랍니다.

 

자 파싱을 하도록합니다.

기본 파싱 소스는 

https://www.vogella.com/tutorials/RSSFeed/article.html

 

RSS feeds with Java - Tutorial

Lars Vogel (c) 2008, 2016 vogella GmbH Version 2.2, 26.09.2016 RSS Feeds with Java. This tutorial explains how to read and create RSS feeds with Java. It uses the Stax XML API. Eclipse is used as the Java IDE and Java7 is used.

www.vogella.com

참조 하였습니다. 좋은 형태이고 저는 살짝 정리를 하였습니다.

다만, 네이버 쪽이라든지 다른 형태의 구성이 약간 상의한 부분이 있어 수정을 했습니다.

전체 소스는 아래 있습니다.

 

RSSFeedParser.java

 

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Iterator;

import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.Characters;
import javax.xml.stream.events.XMLEvent;

import 앞전소스들.Feed;
import 앞전소스들.FeedMessage;

/**
 * @author torrms
 *
 */
public class RSSFeedParser {
	static final String TITLE = "title";
    static final String DESCRIPTION = "description";
    static final String LANGUAGE = "language";
    static final String LINK = "link";
    static final String AUTHOR = "author";
    static final String ITEM = "item";
    static final String LAST_BUILD_DATE = "lastBuildDate";
    
    //message
    static final String PUB_DATE = "pubDate";
    static final String CATEGORY = "category";
    static final String THUMBNAIL = "thumbnail";
    
    
    final URL url;
    
    public RSSFeedParser(String feedUrl) {
        try {
            this.url = new URL(feedUrl);
        } catch (MalformedURLException e) {
            throw new RuntimeException(e);
        }
    }
    
    public Feed readFeed() {
        Feed feed = null;
        try {
            boolean isFeedHeader = true;
            // Set header values intial to the empty string
            String description = "";
            String title = "";
            String link = "";
            String language = "";
            String author = "";
            String lastBuildDate = "";
            String category = "";
            String pubDate = "";
            String thumbnail = "";

            // First create a new XMLInputFactory
            XMLInputFactory inputFactory = XMLInputFactory.newInstance();
            // Setup a new eventReader
            InputStream in = read3();
            
            XMLEventReader eventReader = inputFactory.createXMLEventReader(in);
            // read the XML document
            while (eventReader.hasNext()) {
            	
                XMLEvent event = eventReader.nextEvent();
                
                if (event.isStartElement()) {
                    String localPart = event.asStartElement().getName()
                            .getLocalPart();
                    switch (localPart) {
                    case ITEM:
                        if (isFeedHeader) {
                            isFeedHeader = false;
                            feed = new Feed(title, link, description, language,lastBuildDate);
                        }
                        event = eventReader.nextEvent();
                        break;
                    case TITLE:
                    	
                        title = getCharacterData(event, eventReader);
                        break;
                    case DESCRIPTION:
                        description = getCharacterData(event, eventReader);
                        break;
                    case LINK:
                        link = getCharacterData(event, eventReader);
                        break;
                    case LANGUAGE:
                        language = getCharacterData(event, eventReader);
                        break;
                    case AUTHOR:
                        author = getCharacterData(event, eventReader);
                        break;
                    case LAST_BUILD_DATE:
                    	lastBuildDate = getCharacterData(event, eventReader);
                        break;
	                case PUB_DATE:
	                	pubDate = getCharacterData(event, eventReader);
	                	break;
	                case CATEGORY:
	                	category = getCharacterData(event, eventReader);
	                	break;
	                case THUMBNAIL:
	                	thumbnail = getCharacterData(event, eventReader);
	                	// ex ) <media:thumbnail url="https://imgnews.pstatic.net/image/thumb140/5551/2019/09/04/60286.jpg"/> 형태이므로
	                	@SuppressWarnings("unchecked") Iterator<Attribute> attribue = event.asStartElement().getAttributes();
	                    while(attribue.hasNext()){
	                        Attribute myAttribute = attribue.next();
	                        if(myAttribute.getName().toString().equals("url")){
	                            thumbnail = myAttribute.getValue();
	                        }
	                    }
	                	break;
	                default: 
	                	//System.out.println("localPart:"+ localPart);
	                	break;
	                }
                    
                    
                } else if (event.isEndElement()) {
                    if (event.asEndElement().getName().getLocalPart() == (ITEM)) {
                        FeedMessage message = new FeedMessage();
                        
                        message.setAuthor(author);
                        message.setDescription(description);
                        message.setLink(link);
                        message.setTitle(title);
                        message.setCategory(category);
                        message.setPubdate(pubDate);
                        message.setThumbnail(thumbnail);
                        
                        feed.getMessages().add(message);
                        event = eventReader.nextEvent();
                        continue;
                    }
                }
            }
        } catch (XMLStreamException e) {
            throw new RuntimeException(e);
        }
        return feed;
    }
    
    
    private String getCharacterData(XMLEvent event, XMLEventReader eventReader)
            throws XMLStreamException {
        String result = "";
        event = eventReader.nextEvent();
        if (event instanceof Characters) {
            result = event.asCharacters().getData();
        }
        return result;
    }

//    기존 리더
//    private InputStream read() {
//        try {
//        	return url.openStream();
//        } catch (IOException e) {
//            throw new RuntimeException(e);
//        }
//    }
   
    private InputStream read3() {
        try {
        	ReplacingInputStream  ris = new ReplacingInputStream(url.openStream(), "&apos;", "'");
        	return ris;
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }

    public static InputStream byteArrayToInputStream(byte[] srcBytes) {
        return new ByteArrayInputStream(srcBytes);
    }
    
}

 

기존의 리더리를 통해 읽어서 테스트를 진행 하도록 했습니다. 

정보는 정리가 되어 잘 오고 있었습니다. 그런데...

 

원정보

...

<title>'미드 체르노빌....' XXXX </title> 

...

 

출력정보

...

title = '

...

그렇습니다. 기존의 단순  url.openStream 으로 InputStream 으로는 따옴표가 읽혀 지지 않습니다.

작은 따옴표(싱글 퀘테이션) 등이 말썽으로 원천의 스트림을 출력해보면 

&apos;미드 체르노빌 ...

위와 같이 읽어 오는 것이 바로 치환이 되버려서 오는 겁니다.

짜증이... 변환이 필요합니다. replace 처럼요... 물론 replace를 쓸수는 없습니다. 스트림이니까요

 

외국에 깃 양반을 검색합니다. .... 검색중... 그렇습니다. 전 할 줄 모르고 구글이 해줍니다. ^^;

마침네. simon 이란 시몬이란 양반이 만들어 놓은게 있습니다. 데려옵니다.

 

두둥, ReplacingInputStream 클래스가 바로 그것입니다. 

ReplacingInputStream .java

import java.io.FilterInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.Queue;

/**
 * Created by simon on 8/29/17.
 */
public class ReplacingInputStream extends FilterInputStream {

    private Queue<Integer> inQueue, outQueue;
    private final byte[] search, replacement;

    public ReplacingInputStream(InputStream in, String search, String replacement) {
        super(in);

        this.inQueue = new LinkedList<>();
        this.outQueue = new LinkedList<>();

        this.search = search.getBytes();
        this.replacement = replacement.getBytes();
    }

    private boolean isMatchFound() {
        Iterator<Integer> iterator = inQueue.iterator();

        for (byte b : search) {
            if (!iterator.hasNext() || b != iterator.next()) {
                return false;
            }
        }

        return true;
    }

    private void readAhead() throws IOException {
        // Work up some look-ahead.
        while (inQueue.size() < search.length) {
            int next = super.read();
            inQueue.offer(next);

            if (next == -1) {
                break;
            }
        }
    }

    @Override
    public int read() throws IOException {
        // Next byte already determined.

        while (outQueue.isEmpty()) {
            readAhead();

            if (isMatchFound()) {
                for (@SuppressWarnings("unused") byte a : search) {
                    inQueue.remove();
                }

                for (byte b : replacement) {
                    outQueue.offer((int) b);
                }
            } else {
                outQueue.add(inQueue.remove());
            }
        }

        return outQueue.remove();
    }

    @Override
    public int read(byte b[]) throws IOException {
        return read(b, 0, b.length);
    }

    // copied straight from InputStream inplementation, just needed to to use `read()` from this class
    @Override
    public int read(byte b[], int off, int len) throws IOException {
        if (b == null) {
            throw new NullPointerException();
        } else if (off < 0 || len < 0 || len > b.length - off) {
            throw new IndexOutOfBoundsException();
        } else if (len == 0) {
            return 0;
        }

        int c = read();
        if (c == -1) {
            return -1;
        }
        b[off] = (byte)c;

        int i = 1;
        try {
            for (; i < len ; i++) {
                c = read();
                if (c == -1) {
                    break;
                }
                b[off + i] = (byte)c;
            }
        } catch (IOException ee) {
        }
        return i;
    }
}

사랑해 줍니다.

 

그러면 문제가 해결되어 나오게 됩니다. 아~ 테스트 소스도 올립니다.

단, json 이나 여타 다른 정보는 설정이 된 상태에서 합니다. 

따라서 java APP 소스와 컨트롤러( Controller )는 상황에 맞게 하시면 됩니다.

 

JAVA

import 앞전소스.Feed;
import 앞전소스.FeedMessage;

/**
 * @author torrms
 *
 */
public class testRss {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		RSSFeedParser parser = new RSSFeedParser(
                "http://newssearch.naver.com/search.naver?where=rss&query=3D 프린터");
        Feed feed = parser.readFeed();
        System.out.println(feed);
        for (FeedMessage message : feed.getMessages()) {
            System.out.println(message);

        }
	}

}

 

Controller

// 네이버 뉴스 RSS 테스트(웹) /////////////////////////////////////////////////////////////////////////////////////////	
	@RequestMapping(value = "/getNewsRSSAjax.json")
	public ModelAndView getNewPage(@RequestParam Map<String, Object> commandMap) {
		
		ModelAndView mv = new ModelAndView();
    	mv.setViewName("jsonView");
    	
		
		log.info("getNewPage");
		String result = "false";
		
		try {
			String keyword = (String) commandMap.get("keyword");
			String maxcnt = (String) commandMap.get("maxcnt");
			String Url = "http://newssearch.naver.com/search.naver?where=rss&query=" + keyword;
			log.info("Url:" + Url);
			
			RSSFeedParser parser = new RSSFeedParser(Url);
			Feed feed = parser.readFeed();
			feed.getMessages();

			// TODO 방식 고려
			// 메모리 방식으로 변경을 고려해야함 RSS 너무 자주 부르게 되므로 
			List<Map<String, Object>> listMap = new ArrayList<Map<String, Object>>();
			
			int i = 0 ;
			int maxcnt_int = 0;
			
			if (maxcnt != null)
				maxcnt_int = Integer.valueOf(maxcnt)+1;
			
			for (FeedMessage message : feed.getMessages()) {
				i++;
				if (i == maxcnt_int)	
					break; 
				Map<String, Object> obj = new HashMap<String, Object>();

				obj.put("title"        , message.getTitle()          );
				obj.put("link"         , message.getLink()            );
				obj.put("description"  , message.getDescription()     );
				obj.put("pubdate"      , message.getPubdate()         );
				obj.put("author"       , message.getAuthor()          );
				obj.put("category"     , message.getCategory()        );
				obj.put("thumbnail"    , message.getThumbnail()       );
//				System.out.println(message);
//				System.out.println(obj);
				listMap.add(obj);
			}
			mv.addObject("resultList",listMap);
			result = "true";
			
		} catch (NullPointerException e) {
			log.info("NullPointerException :"  + e.toString());
		} catch (Exception e) {
			log.info(e.toString());
		} 
		mv.addObject("result", result);
		return mv  ;
	}
    

WEB 


<div id="RSS">
        </div>
        
<!-- jquery 선언 후-->

 <script type="text/javaScript" >
 // 시작
    $(function(){
        /////////////////////////////////////////////////////////////////////////
        //RSS 가져오기
        $.ajax({
            url:"<c:url value='/getNewsRSSAjax.json' />", //요청할 데이터 경로.
            type: 'GET',
            data:{
            	keyword: "3D 프린터",
            	maxcnt: "5",
                },
            dataType: "json", //요청할 데이터에 타입.
            crossDomain: true,
            success: function (data) { //성공적으로 요청했왔을 때...
                
                console.info(data);
                $.each(data.resultList,function(i, d){
                    var title=d["title"]; //title 키의 값을 가져옵니다.
                    var date=new Date(d["pubdate"]); //뉴스 작성 날짜 객체 생성
                    var img=d["thumbnail"];
                    var dateString = date_to_str(date);
                    $("#RSS").append("<ul style='height:140px;'><li><img src='"+img+"'/></li><li>" + title+ "</li><li>" + dateString+ "</li></ul><br/>" );    
                    
                });

                },
                error: function (response) {
                      console.info(response.status);
                      console.info(response.error);
                  }     // “success: function”에 종료
            }); // $.ajax() 메서드에 종료
            
    </script>            

1차 버전이 완료 되었습니다.

분명 특수문자 및 지속적으로 부르는 문제가 있을 것으로 보입니다.

자 나머지는 운영 및 반영에 있습니다. 즐프 하세요

그럼 이만,

+ Recent posts