metaweblog API csdn python 实现
一直想同步三个博客,梦想很大,一直在找各种工具,但是一个也没有遇到,今天突然发现了一个叫作open live writer的东西,仔细研究了一下发现是一种叫做Metaweblog API的东西,cnblog 和csdn都是支持的,到github上看了一下,发现了python实现cnblog metaweblog api的程序,所以研究了一下,写出了csdn的api
#coding:utf-8
import xmlrpclib
import os
import sys
import markdown2
import httplib
import mimetypes
username=""
password=""
url="http://write.blog.csdn.net/xmlrpc/index"
#server=xmlrpclib.ServerProxy(url)
class metaWeblog_csdn:
    def __init__(self,url,username,password):
        self.url=url
        #print url,username,password
        #self.p=Proxy()
        #self.p.set_proxy("127.0.0.1:8888")
        self.user=username
        self.passwd=password
        self.server=xmlrpclib.ServerProxy(url,encoding="utf-8")
        self.blog_id=self.getUsersBlogs()[0]['blogid']
        #print self.blog_id
        self.type=["original","report","translated"]
    def newPost(self,title,description,categories,publish):
        return self.server.metaWeblog.newPost(self.blog_id,self.user,self.passwd,
            dict(title=title,description=description,categories=categories),publish)
    def getPost(self,postid):
        return self.server.metaWeblog.getPost(postid,self.user,self.passwd)
    def getCategories(self):
        return self.server.metaWeblog.getCategories(self.blog_id,self.user,self.passwd)
    def getRecentPosts(self,numberOfPosts):
        return self.server.metaWeblog.getRecentPosts(self.blog_id,self.user,self.passwd,numberOfPosts)
    
    def editPost(self,postid,title,content,categories,tags,publish,type=0,description=""):
        return self.server.metaWeblog.editPost(postid,self.user,self.passwd,
            dict(title=title,type=self.type[type],description=description,content=content,categories=",".join(categories),tags=",".join(tags)),publish)
    def newMediaObject(self,abspath):
        with open(abspath,"rb") as f:
            bits=xmlrpclib.Binary(f.read())
        type=mimetypes.guess_type(abspath)[0]
        name=os.path.basename(abspath)
        return self.server.newMediaObject(self.blog_id,self.user,dict(bits=bits,name=name,type=type))
    def getUserInfo(self):
        return self.server.blogger.getUserInfo("0123456789ABCDEF",self.user,self.passwd)
    def deletePost(self,postid,publish):
        return self.server.blogger.deletePost("0123456789ABCDEF",postid,self.user,self.passwd,publish)
    
    def getUsersBlogs(self):
        return self.server.blogger.getUsersBlogs("0123456789ABCDEF",self.user,self.passwd)
# 只是为了通过fiddler的代理进行通信,进行抓包调试
class Proxy(xmlrpclib.Transport):
    def set_proxy(self, proxy):
        self.proxy = proxy
    def make_connection(self, host):
        self.realhost = host
        h = httplib.HTTPConnection(self.proxy)
        return h
    def send_request(self, connection, handler, request_body):
        connection.putrequest("POST", 'http://%s%s' % (self.realhost, handler))
    def send_host(self, connection, host):
        connection.putheader('Host', self.realhost)
if __name__=="__main__":
    if len(sys.argv)!=3:
        print "error"
    else:
        test=metaWeblog_csdn(url,username,password)
        test.newPost(sys.argv[1],markdown2.markdown_path(sys.argv[2]),[""],True)
'''
else:
        test=metaWeblog_csdn(url,username,password)
        with open(sys.argv[2],"r") as blog: 
            test.newPost(title,description,[""],True)
if __name__=="__main__":
    test=metaWeblog_csdn(url,username,password)
    #temp=test.getCategories()[0]
    #for i in temp:
    # print i+":"+temp[i].encode("utf-8")
    #print getblogid()[0]['blogid']
# print test.getUserInfo()
    #print os.listdir("./")
    print test.getCategories()
    #print test.getUsersBlogs()
    #print test.getRecentPosts()
    #print test.getUserInfo()
    
    #print html.encode("utf-8")
    #print test.newPost("test","test","笔记","test",True,html.encode("utf-8"),0)
    try:
        #print test.newPost("test","tests",["笔记"],["tests"],True,"test",0)
    except:
        print "erro"
'''
比较坑的一点是发送categories的时候必须是一个列表,所以他会转化成为xmlrpclib中的array类型,然后才能正常发送,否则会一直爆500 错误
xmlrpclib 代理