消息关闭
    暂无新消息!

客户端

        protected void Page_Load(object sender, EventArgs e)
        {

            Response.Write(OpenReadWithHttps("http://api.xxx.com/Api/ibc_login.ashx", "usname=11111&password=3333", "utf-8"));

        }
        ///<summary>
        ///采用https协议访问网络
        ///</summary>
        ///<param name="URL">url地址</param>
        ///<param name="strPostdata">发送的数据</param>
        ///<returns></returns>
        public string OpenReadWithHttps(string URL, string strPostdata, string strEncoding)
        {
            Encoding encoding = Encoding.Default;
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create(URL);
            request.Method = "post";
            request.Accept = "text/html, application/xhtml+xml, */*";
            request.ContentType = "application/x-www-form-urlencoded";
            byte[] buffer = encoding.GetBytes(strPostdata);
            request.ContentLength = buffer.Length;
            request.GetRequestStream().Write(buffer, 0, buffer.Length);
            HttpWebResponse response = (HttpWebResponse)request.GetResponse();
            using (StreamReader reader = new StreamReader(response.GetResponseStream(), System.Text.Encoding.GetEncoding(strEncoding)))
            {

                ///---拿到远程的JSON,本地处理,并写入COOKIES
                return reader.ReadToEnd();


            }
        }


服务器端

        public void ProcessRequest(HttpContext r)
        {
            r.Response.ContentType = "text/html";
            r.Response.AppendHeader("Access-Control-Allow-Origin", "http://127.0.0.1:7000");

            string username, password;

            username= r.Request.Form["usname"];
            password= r.Request.Form["password"];

            
    //-----验证通过,返回JSON给客户端


        }

8个回答

︿ 2
对于数据的验证方式,并没什么问题。现在挺多采用这种方式的
只是验证数据功能放在page里不太合适。
︿ 1
为何不讲你的验证逻辑,放入一个ashx或者webapi中?
并且验证逻辑相对来说,应该是放入请求处理之前的过滤器,统一验证
︿ 1
根本不要什么 aspx,创建一个巨大的 Page 对象干什么呢?直接就从浏览器端访问 ashx 就足够了。
︿ 0
如果你并不拥有那个 ashx,那么你自己应该使用一个 ashx 来访问那个 ashx。

应该扔掉 aspx 页面机制,直接使用轻量级的 web 数据服务方式。