91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python中web.py開發httpserver如何解決跨域問題

發布時間:2021-08-03 12:37:52 來源:億速云 閱讀:591 作者:小新 欄目:開發技術

這篇文章主要介紹了python中web.py開發httpserver如何解決跨域問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

使用web.py做http server開發時,遇到postman能夠正常請求到數據,但是瀏覽器無法請求到數據,查原因之后發現是跨域請求的問題。

跨域請求,就是在瀏覽器窗口中,和某個服務端通過某個 “協議+域名+端口號” 建立了會話的前提下,去使用與這三個屬性任意一個不同的源提交了請求,那么瀏覽器就認為你是跨域了,違反了瀏覽器的同源策略。 w3c標準中,有針對跨域請求的規范,在響應頭中有以下三種跨域訪問限制:

Access-Control-Allow-Origin:限制允許跨域訪問的源,比如http://192.168.10.12:8080,注意這里僅僅支持*(表示所有源)號或者某個源,不支持多個源,如果要實現多個源,可以自己包裝一個集合,對每次的請求在集合中判斷是否存在,如存在,就放到響應頭中來;

Access-Control-Allow-Methods:限制允許跨域訪問的http方法類型,多個以逗號隔開,比如:POST, GET, OPTIONS,PUT, DELETE

Access-Control-Allow-Headers:限制允許跨域訪問的http頭部,包含這里設置的頭,才允許跨域訪問,比如:Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization

web.py使用web.header() ,可以定義header。

完整的httpserver代碼如下【ap-httpserver.py】

#!/usr/bin/env python 
# encoding: utf-8 
import redis 
import web 
import json 
import string 
from time import time 
 
urls = ( 
  '/qlljx/realtimedata', 'realtimedata' 
  ) 
app = web.application(urls, globals()) 
 
def getResult(): 
 r = redis.Redis(host='127.0.0.1', port=6379) 
 result_list = [] 
 regionlist = r.hgetall('regionlist') 
 timestamp = r.hget('zhongguo_bgp', 'timestamp') 
 for region in regionlist: 
  value = {'mip': str(regionlist[region]), 'region': region, \ 
    'inpps': int(r.hget(region, 'inpps')), 'outpps': int(r.hget(region, 'outpps')), \ 
    'inbps': int(r.hget(region, 'inbps')), 'outbps': int(r.hget(region, 'outbps')), \ 
    'pktpct': string.atof(r.hget(region, 'pktpct')), 'bytpct': string.atof(r.hget(region, 'bytpct'))} 
  result_list.append(value) 
 
 result = {'timestamp': timestamp, 'result': result_list} 
 return json.dumps(result) 
 
class realtimedata: 
 def POST(self): 
  data = web.data() 
  request_type = str(json.loads(data)['type']) 
  if request_type == 'getRealTimeData': 
   result = getResult() 
   web.header("Access-Control-Allow-Origin", "*") 
   #web.header("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE") 
   #web.header("Access-Control-Allow-Headers", "Accept, Content-Type, Content-Length, \ 
   #  Accept-Encoding, X-CSRF-Token, Authorization") 
   return result 
 
if __name__ == "__main__": 
 app.run()

其中只使用了"Access-Control-Allow-Origin" 限制,允許所有源的請求。啟動httpserver:

[root@localhost python]# ./ap-httpserver.py 1216

使用瀏覽器請求數據正常了。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“python中web.py開發httpserver如何解決跨域問題”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

北川| 镶黄旗| 泉州市| 新宾| 吉水县| 诏安县| 台中县| 孝感市| 彰武县| 腾冲县| 双鸭山市| 呼和浩特市| 乌拉特中旗| 温泉县| 新建县| 贵港市| 旬阳县| 雷山县| 米脂县| 昭苏县| 合作市| 大关县| 偃师市| 富民县| 苍梧县| 沙河市| 淮北市| 甘谷县| 西贡区| 遵义县| 湖州市| 子长县| 通州市| 新河县| 宣武区| 大田县| 三原县| 白山市| 昌邑市| 舒城县| 南平市|