1

using System;
2

using System.Data;
3

using System.Configuration;
4

using System.Collections;
5

using System.Web;
6

using System.Web.Security;
7

using System.Web.UI;
8

using System.Web.UI.WebControls;
9

using System.Web.UI.WebControls.WebParts;
10

using System.Web.UI.HtmlControls;
11

using System.Text;
12
13

public partial class pay : System.Web.UI.Page
14
{
15
protected void Page_Load(object sender, EventArgs e)
16
{
17
Encoding gb2312 = Encoding.GetEncoding("gb2312");
18
Response.ContentEncoding = gb2312;
19
Request.ContentEncoding = gb2312;
20
}
21
protected void ImageButton1_Click(object sender, ImageClickEventArgs e)
22
{
23
if (Request.Cookies[FormsAuthentication.FormsCookieName] != null)
24
{
25
Vlike_DB_read a = new Vlike_DB_read();
26
string zfb_ddh=a.get_zfb_id(Membership.GetUser().UserName,Convert.ToInt32(DropDownList1.SelectedValue));
27
Response.Redirect(img("0001", "包月", "影視包月 10元/月", zfb_ddh, "10.00", Membership.GetUser().UserName.ToUpper(), DropDownList1.SelectedValue));
28
}
29
else
30
{
31
Response.Write("<script type='text/javascript'>alert('請先登錄!');</script>");
32
}
33
}
34
35
private string img(string strcmd, string strSub, string strSubinfo, string strid, string strMoney, string strUser, string strNum)
36
{
37
string strsellerEmail = "341081@qq.com"; //賣家支付寶賬號
38
string strAc = ""; //賣家支付寶安全校驗碼
39
string INTERFACE_URL = "https://www.alipay.com/payto:";
40
string strCmd = strcmd; //命令字
41
string strSubject = strSub; //商品名
42
string strBody = strSubinfo; //商品描述
43
string strOrder_no = strid; //商戶訂單號
44
string strPrice = strMoney; //商品單價 0.01~50000.00
45
string rurl = "http://"; //商品展現網址
46
string strType = "2"; //type支付類型 1:商品購買2:服務購買3:網絡拍賣4:捐贈
47
string strNumber = strNum; //購買數量
48
string strTransport = "3"; //發貨方式 1:平郵2:快遞3:虛擬物品
49
string strOrdinary_fee = ""; //平郵運費
50
string strExpress_fee = ""; //快遞運費
51
string strReadOnly = "true"; //交易信息是否只讀
52
string strBuyer_msg = ""; //買家給賣家的留言
53
54
string strBuyer = ""; //買家EMAIL
55
string strBuyer_name = strUser; //買家姓名
56
string strBuyer_address = ""; //買家地址
57
string strBuyer_zipcode = ""; //買家郵編
58
string strBuyer_tel = ""; //買家電話號碼
59
string strBuyer_mobile = ""; //買家手機號碼
60
string strPartner = ""; //合做夥伴ID 保留字段
61
return CreatUrl(strsellerEmail, strAc, INTERFACE_URL, strCmd, strSubject, strBody,
62
strOrder_no, strPrice, rurl, strType, strNumber, strTransport,
63
strOrdinary_fee, strExpress_fee, strReadOnly, strBuyer_msg, strBuyer,
64
strBuyer_name, strBuyer_address, strBuyer_zipcode, strBuyer_tel,
65
strBuyer_mobile, strPartner);
66
}
67
private string CreatUrl(string strsellerEmail, string strAc, string INTERFACE_URL, string strCmd, string strSubject, string strBody, string strOrder_no, string strPrice, string rurl, string strType, string strNumber, string strTransport, string strOrdinary_fee, string strExpress_fee, string strReadOnly, string strBuyer_msg, string strBuyer, string strBuyer_name, string strBuyer_address, string strBuyer_zipcode, string strBuyer_tel, string strBuyer_mobile, string strPartner)
68
{ //如下參數值不能留空
69
70
string str2CreateAc = "";
71
str2CreateAc += "cmd" + strCmd + "subject" + strSubject;
72
str2CreateAc += "body" + strBody;
73
str2CreateAc += "order_no" + strOrder_no;
74
str2CreateAc += "price" + strPrice;
75
str2CreateAc += "url" + rurl;
76
str2CreateAc += "type" + strType;
77
str2CreateAc += "number" + strNumber;
78
str2CreateAc += "transport" + strTransport;
79
str2CreateAc += "ordinary_fee" + strOrdinary_fee;
80
str2CreateAc += "express_fee" + strExpress_fee;
81
str2CreateAc += "readonly" + strReadOnly;
82
str2CreateAc += "buyer_msg" + strBuyer_msg;
83
str2CreateAc += "seller" + strsellerEmail;
84
str2CreateAc += "buyer" + strBuyer;
85
str2CreateAc += "buyer_name" + strBuyer_name;
86
str2CreateAc += "buyer_address" + strBuyer_address;
87
str2CreateAc += "buyer_zipcode" + strBuyer_zipcode;
88
str2CreateAc += "buyer_tel" + strBuyer_tel;
89
str2CreateAc += "buyer_mobile" + strBuyer_mobile;
90
str2CreateAc += "partner" + strPartner;
91
str2CreateAc += strAc;
92
93
94
string acCode = GetMD5(str2CreateAc);
95
96
string parameter = "";
97
98
parameter += INTERFACE_URL + strsellerEmail + "?cmd=" + strCmd;
99
parameter += "&subject=" + Server.UrlEncode(strSubject);
100
parameter += "&body=" + Server.UrlEncode(strBody);
101
parameter += "&order_no=" + strOrder_no;
102
parameter += "&url=" + rurl;
103
parameter += "&price=" + strPrice;
104
parameter += "&type=" + strType;
105
parameter += "&number=" + strNumber;
106
parameter += "&transport=" + strTransport;
107
parameter += "&ordinary_fee=" + strOrdinary_fee;
108
parameter += "&express_fee=" + strExpress_fee;
109
parameter += "&readonly=" + strReadOnly;
110
parameter += "&buyer_msg=" + strBuyer_msg;
111
parameter += "&buyer=" + strBuyer;
112
parameter += "&buyer_name=" + Server.UrlEncode(strBuyer_name);
113
parameter += "&buyer_address=" + strBuyer_address;
114
parameter += "&buyer_zipcode=" + strBuyer_zipcode;
115
parameter += "&buyer_tel=" + strBuyer_tel;
116
parameter += "&buyer_mobile=" + strBuyer_mobile;
117
parameter += "&partner=" + strPartner;
118
parameter += "&ac=" + acCode;
119
120
return parameter;
121
}
122
123
private static string GetMD5(string s)
124
{
125
126
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
127
byte[] t = md5.ComputeHash(System.Text.Encoding.GetEncoding("gb2312").GetBytes(s));
128
System.Text.StringBuilder sb = new System.Text.StringBuilder(32);
129
for (int i = 0; i < t.Length; i++)
130
{
131
sb.Append(t[i].ToString("x").PadLeft(2, '0'));
132
}
133
return sb.ToString();
134
}
135
}
136
1

<%@ Import NameSpace="System.Data.SqlClient"%>
2

<%@ Import NameSpace="System.Data"%>
3

<%@ Import NameSpace="System.Web"%>
4

<%@ Import NameSpace="System.IO"%>
5

<%@ Import NameSpace="System.Net"%>
6

<%@ Import NameSpace="System.Text"%>
7

<%@ Import NameSpace="System.Security.Cryptography"%>
8

<%@ Page Language="C#"%>
9
10

<script language="C#" runat="server">
11

private string returnTxt = "N"; //返回給支付寶通知接口的結果
12

private string alipayNotifyURL = "http://notify.alipay.com/trade/notify_query.do?"; //支付寶查詢接口URL
13

private string myalipayEmail = "341081@qq.com"; //商戶的支付寶Email
14

private string constPaySecurityCode = ""; //碼
15

private SqlConnection conn = new SqlConnection();
16
17

private string GetMD5(string s)
18
{
19
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
20
byte[] t = md5.ComputeHash(System.Text.Encoding.GetEncoding("gb2312").GetBytes(s));
21
StringBuilder sb = new StringBuilder(32);
22
for (int i = 0; i < t.Length; i++)
23
{
24
sb.Append(t[i].ToString("x").PadLeft(2, '0'));
25
}
26
return sb.ToString();
27
}
28
private String Get_Http(String a_strUrl,int timeout)
29
{
30
string strResult ;
31
try
32
{
33
System.Net.HttpWebRequest myReq = (System.Net.HttpWebRequest)System.Net.HttpWebRequest.Create(a_strUrl) ;
34
myReq.Timeout = timeout;
35
System.Net.HttpWebResponse HttpWResp = (System.Net.HttpWebResponse)myReq.GetResponse();
36
Stream myStream = HttpWResp.GetResponseStream () ;
37
StreamReader sr = new StreamReader(myStream , System.Text.Encoding.Default);
38
System.Text.StringBuilder strBuilder = new System.Text.StringBuilder();
39
while (-1 != sr.Peek())
40
{
41
strBuilder.Append(sr.ReadLine()+"\r\n");
42
}
43
strResult = strBuilder.ToString();
44
}
45
catch(Exception exp)
46
{
47
48
strResult = "錯誤:" + exp.Message ;
49
}
50
return strResult ;
51
}
52
53
public void send(string sql)
54
{
55
string dbconn = "data source=127.0.0.1;UID=Cm;PWD=fallenangel;database=text";
56
conn = new SqlConnection(dbconn);
57
conn.Open();
58
SqlCommand cmd = new SqlCommand(sql, conn);
59
int aa = cmd.ExecuteNonQuery();
60
conn.Close();
61
}
62
63
private void Page_Load(object sender, System.EventArgs e)
64
{
65
//檢查支付寶通知接口傳遞過來的參數是否合法
66
string msg_id = System.Web.HttpContext.Current.Request["msg_id"];
67
string order_no = System.Web.HttpContext.Current.Request["order_no"];
68
string gross = System.Web.HttpContext.Current.Request["gross"];
69
string buyer_email = System.Web.HttpContext.Current.Request["buyer_email"];
70
string buyer_name = System.Web.HttpContext.Current.Request["buyer_name"];
71
string buyer_address = System.Web.HttpContext.Current.Request["buyer_address"];
72
string buyer_zipcode = System.Web.HttpContext.Current.Request["buyer_zipcode"];
73
string buyer_tel = System.Web.HttpContext.Current.Request["buyer_tel"];
74
string buyer_mobile = System.Web.HttpContext.Current.Request["buyer_mobile"];
75
string action = System.Web.HttpContext.Current.Request["action"];
76
string s_date = System.Web.HttpContext.Current.Request["date"];
77
string ac = System.Web.HttpContext.Current.Request["ac"];
78
string notify_type = System.Web.HttpContext.Current.Request["notify_type"];
79
80
alipayNotifyURL = alipayNotifyURL + "msg_id=" + msg_id + "&email=" + myalipayEmail + "&order_no=" + order_no;
81
82
83
//獲取支付寶ATN返回結果,true和false都是正確的訂單信息,invalid 是無效的
84
string responseTxt=Get_Http(alipayNotifyURL,120000);
85
86
string Str = "msg_id" + msg_id + "order_no" + order_no + "gross" + gross + "buyer_email" + buyer_email + "buyer_name" + buyer_name + "buyer_address" + buyer_address + "buyer_zipcode" + buyer_zipcode + "buyer_tel" + buyer_tel + "buyer_mobile" + buyer_mobile + "action" + action + "date" + s_date + constPaySecurityCode ;
87
88
string ac_code=GetMD5(Str);
89
90
if(action=="test") //支付寶接口測試是否有效
91
{
92
returnTxt = "Y";
93
}
94
if(action=="sendOff") //發貨通知
95
{
96
if(responseTxt.Substring(0,4)=="true" || responseTxt.Substring(0,4)=="fals")//ATN,驗證消息是否支付寶發過來
97
{
98
if(ac_code==ac)//驗證消息是否被修改
99
{
100
//數據庫操做
101
}
102
}
103
}
104
if(action=="checkOut") //交易完成通知
105
{
106
returnTxt = "N";
107
if(responseTxt.Substring(0,4)=="true" || responseTxt.Substring(0,4)=="fals")//ATN,驗證消息是否支付寶發過來
108
{
109
if(ac_code==ac)//驗證消息是否被修改
110
{
111
//數據庫操做
112
}
113
}
114
}
115
System.Web.HttpContext.Current.Response.Write(returnTxt);
116
}
117
</script>118