草原上的兩匹馬! 打從當年微信開始佈局公眾號之初時,估計就已經想到了與支付寶正面衝突的場面,所以微信先來個瞞天過海,在春晚搞了個微信紅包,那叫一個火呀,此時的云云隱隱感覺到些許不安。 早期的微信開發者可能都知道,微信公眾號剛開始的時候接入支付要交巨額的保證金,根據行業不同,金額也不同,但也有大幾萬呢 ...
草原上的兩匹馬!
打從當年微信開始佈局公眾號之初時,估計就已經想到了與支付寶正面衝突的場面,所以微信先來個瞞天過海,在春晚搞了個微信紅包,那叫一個火呀,此時的云云隱隱感覺到些許不安。
早期的微信開發者可能都知道,微信公眾號剛開始的時候接入支付要交巨額的保證金,根據行業不同,金額也不同,但也有大幾萬呢。這讓很大一部分微型企業望而卻步(老子創業時,註冊公司的註冊資金都免了,用個支付,你還要保證金),所以,大家果斷用支付寶。
這樣一來,騰哥的如意算盤算是打到自己腳面了,本打算可以用企業交的保證金拿去做網貸的,可是大家不買賬。不買賬也就算了,竟然用競爭對手的,這廝氣的直抓屁股,怎麼辦呢?騰哥靈機一動,既然大家不想交保證金,那咱們乾脆免費吧。
好嘛,俗話說的話,天下沒有免費的午餐,要免費可以,但你要先認證(乖乖交300大洋,騰哥是賊心不死呀,3w交不起,300總交得起吧)。於是乎,微信支付的商家開通量確實是有了一個穩定的增長。
等等…………
“為毛每個月還是有那麼多的流量流到支付寶呢?”,騰哥怒目圓睜,瞪著小龍哥。小龍哥委屈的都快尿了,躲在一邊的牆角,低聲道:“他們都說咱們的文檔太爛了,他們看不懂,不知道怎麼開發”。
“我不想聽解釋,你知道我要的是什麼!!”,騰哥依舊不依不饒。但望著牆角的小龍,基情油然而生,仿佛動了惻隱之心。不忍再責備小龍,揚長而去。
一言不合就屏蔽!
話說,自從那日小龍哥被騰哥狗血噴頭後,百思不得姐,頭髮都要掉光了。眼看下周公司例會在即,如再想不到解決方式,恐怕帥位不保呀。思來想去,唯有兵行險招,老子玩不過你,就不讓你來我家玩。於是乎,一夜之間,所有從微信里跳轉到阿裡系的功能變數名稱均無法打開。不管怎樣,從微信端流入支付寶的流量起碼錶面上看起來好看的多,騰哥與小龍哥也恢復了往日的基情歲月。
流氓不可怕,就怕流氓有文化
"報告馬總,近日深圳龍騰作怪,堵我流量入口,眾開發者怨聲載道,這可如何是好,咱不能棄咱們的衣食父母而不顧呀"
馬總此時剛練完一日一賤《獨孤九賤》,忽聽探子來報,竟有人堵我糧道,豈有此理。大手一揮,寫下幾個大字“吾乃風清揚,從小做流氓,對我耍流氓,讓他直喊娘”。交於探子。此探子雖說學識淵博,可也無從揣摩馬總心思,正要走時,忽見字的背面若隱若現,定睛一看,著實驚喜萬分,這就是傳說中的《獨孤九賤》呀。
第一式:工欲善其事必先利其器
想在微信里使用支付寶支付,那麼,首先你要有個支付寶賬號,並申請開通了《手機網站支付介面》,申請地址是:https://b.alipay.com/signing/productDetail.htm?productId=I1011000290000001001
第二式:北冥神功
成功的捷徑就是,拿別人造好的輪子裝在自己的車上,北冥神功也是此道理。支付寶的開發人員真的是善良的,深知一眾屌絲開發者苦逼至極,為了更方便的接入支付寶支付,人家把代碼封裝的傻瓜化。這才是咱們需要的嘛,我就是想要在我的網站里接個支付而已,幹嘛去讓我搞一堆百年不用一次的什麼md5,sha1,公鑰,密鑰等等。多點真誠,少點套路才是道理。支付的demo的下載地址是:
https://doc.open.alipay.com/doc2/detail?treeId=60&articleId=103564&docType=1
下載完成後,解壓壓縮包,壓縮包中有兩個文件夾,分別是:MD5簽名方式與RSA簽名方式,本king推薦用MD5方式,接入簡單,不要問我為什麼!有錢!任性!
第三式:連城訣
介面許可權申請了,demo也有了,那咱們就只需要把demo中的參數換成自己的就行了。
首先,在代碼的AlipayConfig中配置合作者身份ID與MD5密鑰(C#語言,其他語言類似)。這兩個參數需要登錄支付寶,在《商家服務》頁面查看。如下圖:
一路火花帶閃電地配置完後,咱們就可以手機端瀏覽了。如下圖:
484很簡單, 484很清爽,484很傻瓜化。
騰哥,趕緊讓你的小弟看看,啥叫善待自己的衣食父母,趕緊擦亮你們爾等的鈦合金狗眼。
額,貌似嘚瑟太早,容易閃著腰,點擊平【確認】按鈕之後的頁面,頓時差點嚇得生活不能自理。見下圖:
這是什麼鬼,寶寶年紀小,看不懂英文。城市套路深,我要回農村……~~~~(>_<)~~~~
第四式:凌波微步
俗話說的話,你賤我三分,我賤你一丈。雲哥可是懂八國英語的人。畢竟在別人家地盤,不讓我玩,我就翻你家牆頭。
快跟著我一起來,左手右手一個慢動作……。
新一代全國程式員廣播體操現在開始:
1、找到支付寶的機器人。(納尼?你找不到,好吧,我來教你。)
在支付寶頁面的《簽約管理》的右邊,有個機器人頭像,看著了吧。
磨嘰啥,趕緊點,進去之後,二話不說,直接發送“微信中使用支付寶”,奇跡的時刻就要到了:
雲哥的給力,襯托出騰哥就是比較疼。傳送門已經給我們了,趕緊進去看看秘籍吧。
進入頁面後,會有一個征討微信的說明,大概意思就是,騰哥刷流氓,雲哥心不爽,雲哥盡心力,教咱去他牆。
趕緊下載方案文件,解壓後有驚喜。
duang~~~
一個文件變成了多個文件,是不是很神奇……
額,其他的文件咱都不看了, 有興趣修煉的話,自己研究去。現在跟著我做下個動作,伸展運動……
2.打開【alipay_in_weixin工具說明】文件夾,將文件中的ap.js和pay.htm文件拷貝到項目中,註意要放到同一個文件夾哦。
然後,由於支付寶給的代碼是使用表單html形式提交的數據,這個不太適合集成這個插件。咱們稍微改動下。
首先,在AlipaySubmit類中,找到BuildRequestParaToString方法,將private改成public,然後return的時候,加上支付寶的網關地址。改之後的代碼如下所示:
public static string BuildRequestParaToString(SortedDictionary<string, string> sParaTemp, Encoding code)
{
//待簽名請求參數數組
Dictionary<string, string> sPara = new Dictionary<string, string>();
sPara = BuildRequestPara(sParaTemp);
//把參數組中所有元素,按照“參數=參數值”的模式用“&”字元拼接成字元串,並對參數值做urlencode
string strRequestData = Core.CreateLinkStringUrlencode(sPara, code);
return GATEWAY_NEW + strRequestData;
}
然後仿照demo中的default.aspx頁面新建一個頁面,命名為pay.aspx,此頁面要引用ap.js,在pay類中新建方法,如下:
public string GetPayUrl()
{
string out_trade_no =string.Format("{0:yyyyMMddHHmmssfff}",DateTime.Now);
string subject = "裝逼訂單";
string total_fee ="0.01";
string show_url = "http://www.baidu.com";
string body = "";
SortedDictionary<string, string> sParaTemp = new SortedDictionary<string, string>();
sParaTemp.Add("partner", Config.partner);
sParaTemp.Add("seller_id", Config.seller_id);
sParaTemp.Add("_input_charset", Config.input_charset.ToLower());
sParaTemp.Add("service", Config.service);
sParaTemp.Add("payment_type", Config.payment_type);
sParaTemp.Add("notify_url", Config.notify_url);
sParaTemp.Add("return_url", Config.return_url);
sParaTemp.Add("out_trade_no", out_trade_no);
sParaTemp.Add("subject", subject);
sParaTemp.Add("total_fee", total_fee);
sParaTemp.Add("show_url", show_url);
sParaTemp.Add("app_pay","Y");//啟用此參數可喚起錢包APP支付。
sParaTemp.Add("body", body);
return Submit.BuildRequestParaToString(sParaTemp, Encoding.UTF8);
}
註意哦,用的時候要把對應的參數改成自己的,不要傻到拿別人參數自己用,還不知道哪裡錯了。
再然後,在頁面中,就可以調用了。
<script>
var pay = function () {
_AP.pay("<%=GetPayUrl()%>");
}
</script>
<button type="button" onclick="pay()">支付</button>
現在再點擊支付按鈕,跳轉的頁面就好看多啦。
484好看多了。這個頁面的潛臺詞就是:“小兔子乖乖,快到碗里來”。
趕緊試試在瀏覽器打開的效果吧:
( ⊙o⊙ )哇,從微信里,直接跳到了支付寶app支付,有木有很屌的樣子。知道大家喜歡高清無碼的,所以,我故意打了馬賽克。哈哈哈,快,別說話,吻我~。
支付完成後,需要咱們手動關閉瀏覽器,然後會自動返回到微信里咱們發起支付的頁面。不過,貌似有點不對,微信里顯示的還是那個“快到碗里來的提示”,這個體驗就不有點不好了。真是要死啦。……
終極招式:隨心所欲
回顧整個流程,接入插件前與接入後的代碼結構區別是,多了兩個文件,一個ap.js,一個是pay.htm,既然文件都在咱們這,那還不是想怎麼改,怎麼改呢。
從調用的方式上,可以看出,js里有個方法pay(url),此方法接收一個參數。然後咱們打開ap.js文件看看。
媽呀,就是這麼任性,幸虧咱穿了淘寶5塊10片包郵的尿不濕,這又給嚇尿了。一行行亂碼,一片片尿不濕呀。
其實靜下心來仔細看,還是看得懂滴。其他的代碼無法就是一個加解密的方法,咱就順藤摸瓜吧 。
其實pay方法只是將傳過來的參數加密後,跳轉到pay.htm後,然後判斷是否是在微信的瀏覽器環境,如果不是的話,就解密,跳轉到真實的支付頁面。那咱們只需要修改下pay方法就能實現咱們的目的了。
首先呢,在pay方法中添加一個參數,可以為orderid,然後同加密後的url一起跳轉到pay.htm,再然後,在pay.htm頁面中獲取到orderid,寫個定時器,每隔幾秒中去伺服器查詢訂單的支付狀態,如果支付成功了,就跳轉到支付成功的頁面。用戶再返回微信的時候看到的就不會是“快到碗里來”的提示了。
是不是很屌,你知道怎麼整了嗎?不知道是吧,不知道我也沒辦法,因為我沒準備貼出源碼。
哈哈,我就是我,不一樣的煙火。
╮(╯▽╰)╭,先彆著急關頁面呀,看到下麵的二維碼了吧,關註不關註你看心情,反正我也不准備求你。
覺得本文可以吐槽的話,有本事就發到朋友圈,讓全世界的朋友都來吐槽我吧。