Python開發入門與實戰20-微信開發配置

高洛峰
發布: 2017-02-14 10:53:05
原創
1658 人瀏覽過

隨著行動互聯網時代的來臨,微信已經成為行動互聯網行動端的主要入口,現在許多的大型企業都有自己的微信服務號,如:銀行業有自己的微銀行,基金公司的公眾服務號碼。透過微信入口可以方便快速的實現企業提供的服務。

Python開發入門與實戰20-微信開發配置

如:上圖招商銀行的公眾服務號,上面的功能的實現是依據“微信”提供的接口開發規範完成的,由於“微信”是運行在互聯網上的,本章節開始我們將結合前面章節發布的新浪「雲」服務來實現微信公眾號的一些功能實例。

20.1. 搭建開發環境

微信公眾號的註冊請參網上相關資料,如參考《微信公眾平台入門到精通》

20.1.1. 用管理員登陸微信公眾平台

Python開發入門與實戰20-微信開發配置20.1.1. 用管理員登陸微信公眾平台

。中心->伺服器配置->修改配置,我們修改結果如下圖:

Python開發入門與實戰20-微信開發配置

現在我們點擊提交按鈕,「微信」會提示token驗證失敗的錯誤提示,根據」微信」SDK要求,我們首先要實現一個提供給”微信”伺服器的握手請求服務,以便”微信”伺服器來校驗我們的伺服器是否回應。

Python開發入門與實戰20-微信開發配置

20.1.2. 根據配置我們需要實現wechat的url

這裡我們在工程中新建一個叫wechat的APP來專門處理與」微信」請求的交互服務,一如前面說的面向對象裡的功能內聚的原則。

Python開發入門與實戰20-微信開發配置

接下來我們先在wechat的views.py裡面增加程式碼如下:

from django.http import
import RequestContext
from
django.views.decorators.csrf
import csrf_exempt
import
csrf_exempt
import
hashlib TOKEN
=
"mysaesite
" #必須與微信Token一致

@csrf_exemptdefwechat(request):    if request.method == 'GET':
        response = HttpResponse(checkSignature(request),content_type="text/plain")        
        return response    else:        
        return Nonedef checkSignature(request):    global TOKEN
    signature = request.GET.get("signature", None)
    timestamp = request.GET.get("timestamp", None)
    nonce = request.GET.get("nonce", None)
    echoStr = request.GET.get("echostr",None)
    token = TOKEN
    tmpList = [token,timestamp,nonce]
    tmpList.sort()
    tmpstr = "%s%s%s" % tuple(tmpList)
    tmpstr = hashlib.sha1(tmpstr).hexdigest()    
    if tmpstr == signature:        
    return echoStr    
    else:        
    return None
登入後複製
"""Definition of urls for mysite."""from django.conf.urls import patterns, include, url# Uncomment the next two lines to enable the admin:# from django.contrib import admin# admin.autodiscover()from inventory import viewsimport wechat.viewsurlpatterns = patterns('',    # Examples:
    # url(r'^$', 'mysite.views.home', name='home'),
    # url(r'^mysite/', include('mysite.mysite.urls')),

    # Uncomment the admin/doc line below to enable admin documentation:
    # url(r'^admin/doc/', include('django.contrib.admindocs.urls')),

    # Uncomment the next line to enable the admin:
    # url(r'^admin/', include(admin.site.urls)),
    url(r'^AddInStockBill/$', views.AddInStockBill),
    url(r'^AddItem/$', views.AddItem),
    url(r'^success/$', views.success), 
    url(r'^search/$',views.search), 
    url(r'^inventoryQuery/$',views.inventoryQuery),
    url(r'^getInventoryByItemName/$',views.getInventoryByItemName),
    url(r'^inventoryQueryExtjs/$',views.inventoryQueryExtjs),
    url(r'^inventoryQueryBootstrap/$',views.inventoryQueryBootstrap),    url(r'^wechat/$',wechat.views.wechat),)
登入後複製
接下來,我們把urls.py檔案和wechat app 目錄和檔案更新到新浪雲上,我們就可以訪問wechat了,訪問結果如下圖:

現在,我們點擊剛開發中心修改配置介面的提交按鈕,微信驗證服務通過,如下圖。

20.1.3. 程式碼註解

checkSignature函數功能就是確認GET請求是否來自「微信」伺服器,如果請求來至微信伺服器,原樣回傳echoStr資料則存取生效,否則存取失敗

20.2. 小結

現在我們完成了我們的開發的web服務在微信開發中心的配置,下一章我們將透過簡單範例來說明如何進行微信公眾服務號的開發。

更多Python開發入門與實戰20-微信開發配置相關文章請關注PHP中文網!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!