python3實現的web端json通信協議


之前有用python3實現過tcp協議的,后來又實現了http協議的通信,今天公司想做一個功能自動測試系統,

下午弄了一會,發現json格式的實現可以更簡單一點,代碼如下:簡單解說一下,一般與服務器通信分兩塊,一塊是get協議,一塊是post協議,

get協議很簡單,直接就可訪問了,post協議,實際上把data數據用起來,程序直接會自動辨別類型。

在寫的過程中遇到3個問題:

1 在實現post協議時曾遇到錯誤,

大致說數據格式的問題,解決方法很簡單,轉為utf-8格式:bytes(data, 'utf8') ,

2 獲取到的json數據遇到里面中文時遇到編碼問題

發現表現出0xaa0xbb0xcc0xdd這樣的編碼,json加載時調用utf8即可,使用這一句代碼:json.loads(rawtext.decode('utf8'))

3 打印出json時表現出一行很長很長的字符串

長長的字符串看了非常痛苦,根本看不清json里面各對像的關系,網上說用什么json.tool方法解決,不過那是針對命令行的,我這是在調試過程中還是希望直接打印出來,

采用如下代碼:print (json.dumps(jsonStr, sort_keys=False, ensure_ascii= False, indent=2)) ,這里需要注意ensure_ascii必須為False,否則里面有中文時

看到的又是0xx什么的,indent=2表示格式化json顯示,sort_keys則表示此json無需排序

 

#!/usr/bin/evn python3
#coding=utf-8

# 針對web端json協議的通信庫,通信協議為json,傳出的data為json格式,接收的數據也是json格式
# 外界調用時可先初始化web_json類,如下所示:
# get調用
# web = web_json("http://baidu.com/")
# params = "abcd/select/100000?userID=1234&groupID=79"
# web.url_get(params)
# 
# post調用
# web = web_json("http://baidu.com/")
# params = "abcd/select/100000"
# data = '{"name": "jack", "id": "1"}'
# web.url_post(params, data)

from urllib.request import urlopen
from urllib.parse import quote
import json

class web_json:
    def __init__(self, base_url):
        self.base_url = base_url
        
    def get_url_data(self, params, data):
        web = urlopen(self.base_url + params, data)
        print (web.url)
        print ("status: " , web.status)
        rawtext = web.read()
        jsonStr = json.loads(rawtext.decode('utf8'))   
        print (json.dumps(jsonStr, sort_keys=False, ensure_ascii= False, indent=2))
        return jsonStr       
    
    # get方法
    def url_get(self, params):
        return self.get_url_data(params, None)
    
    # post方法
    def url_post(self, params, data):
        data=bytes(data, 'utf8')
        return self.get_url_data(params, data)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM