天猫登录源码 POST C#

HttpHelper 请从网络中搜索;

public partial class LoginTMall : Form

{

public LoginTMall()

{

InitializeComponent();

}

private void btnLogin_Click(object sender, EventArgs e)

{

string postDate = getPostString();

HttpItem itemLogin = new HttpItem()

{

URL = "https://login.taobao.com/member/login.jhtml",

Method = "POST",

ContentType = "application/x-www-form-urlencoded",

Referer = "https://www.taobao.com/",

Postdata = postDate,

Cookie = CommonDB.tmailModel.cookie,

};

HttpHelper helperLogin = new HttpHelper();

HttpResult resultLogin = helperLogin.GetHtml(itemLogin);

CommonDB.tmailModel.cookie = resultLogin.Cookie;

string html = resultLogin.Html;

if (html.ToLower().Contains("gotoURL:\"http://www.tmall.com/\"".ToLower()) && html.ToLower().Contains("gotoTop:true".ToLower()))             {

MessageBox.Show("登录成功!");

}

else

{

string namePwdNotMatch = "您输入的密码和账户名不匹配,请重新输入。";

string reInputcheckcode = "验证码错误,请重新输入";

string checkCodeNeedInput = "为了您的账户安全,请输入验证码。";

if (html.Contains(namePwdNotMatch))

{

MessageBox.Show(namePwdNotMatch);

return;

}

if (html.Contains(checkCodeNeedInput) || html.Contains(reInputcheckcode))

{

string checkCodeUrl = "<img id=\"J_StandardCode_m\" src=\"https://s.tbcdn.cn/apps/login/static/img/blank.gif\"";

int index = html.IndexOf(checkCodeUrl);

html = html.Substring(index, html.Length - index);

string datasrc = "data-src=\"";

index = html.IndexOf(datasrc);

html = html.Substring(index, html.Length - index);

html = html.TrimStart(datasrc.ToCharArray());

index = html.IndexOf("\"");

html = html.Substring(0, index);

setCheckCode(html);

MessageBox.Show(checkCodeNeedInput);

return;

}

}

}

private void setCheckCode(string url)

{

try

{

picBox.Image = Image.FromStream(System.Net.WebRequest.Create(url).GetResponse().GetResponseStream());

}             catch (Exception ex)             {                 Text = ex.Message;             }         }

private void LoginTMall_Load(object sender, EventArgs e)         {         }

private string getPostString()

{

PostParaPair model = new PostParaPair();

string checkCode = txtCheckCode.Text.Trim();

if (checkCode.Length != 0)

{

model.Add(new PostParaPair()

{ Key = "TPL_checkcode", Value = checkCode });

}

string pwd = txtPwd.Text.Trim();

if (pwd.Length != 0)

{

model.Add(new PostParaPair() { Key = "TPL_password", Value = pwd });             }

string name = txtUName.Text.Trim();

if (name.Length != 0)

{

model.Add(new PostParaPair() { Key = "TPL_username", Value = name });

}

model.Add(new PostParaPair() { Key = "allp", Value = "assets_css=2.0.0/login_pc.css&enup_css=2.0.0/enup_pc.css&assets_js=2.3.8/login_performance.js" });

model.Add(new PostParaPair() { Key = "CtrlVersion", Value = "1,0,0,7" });             model.Add(new PostParaPair() { Key = "fc", Value = "default" });

model.Add(new PostParaPair() { Key = "from", Value = "tmall" });

model.Add(new PostParaPair() { Key = "full_redirect", Value = "true" });

model.Add(new PostParaPair() { Key = "loginASR", Value = "0" });

model.Add(new PostParaPair() { Key = "loginASRSuc", Value = "0" });

model.Add(new PostParaPair() { Key = "loginsite", Value = "0" });

model.Add(new PostParaPair() { Key = "loginType", Value = "3" });

model.Add(new PostParaPair() { Key = "naviVer", Value = "ie|9" });

model.Add(new PostParaPair() { Key = "newlogin", Value = "0" });

model.Add(new PostParaPair() { Key = "osVer", Value = "windows|6.1" });

model.Add(new PostParaPair() { Key = "poy", Value = "XOR_1_000000000000000000000000000000_65585B56440B6279736B017E6F0065" });             model.Add(new PostParaPair() { Key = "pstrong", Value = "2" });

model.Add(new PostParaPair() { Key = "sr", Value = "1366*768" });

model.Add(new PostParaPair() { Key = "style", Value = "miniall" });

model.Add(new PostParaPair() { Key = "sub", Value = "false" });

model.Add(new PostParaPair() { Key = "support", Value = "000001" });

model.Add(new PostParaPair() { Key = "tid", Value = "XOR_1_000000000000000000000000000000_602B4C5345787C007D7D057F" });             model.Add(new PostParaPair() { Key = "TPL_redirect_url", Value = "http://www.tmall.com/" });

model.Add(new PostParaPair() { Key = "ua", Value = "128JqNYCOQNFccufusYO71CC4hyOrlKBYpjQqg=|JaNECYpwPbpBBIV6MrRKA+k=|JKFGYfR2T4A7K/NKU5Z/L7pIFo1kT5E0LPRIR9JEZQ==|I6VcDJljK61XG5xuJKdYFZdpL6hNAYJwOL5FAIR9NLRLA4F5NbRdfA==|IqRWBuoQQMI5ceoQXMcuMb0UGshidflPWs9ZeA==|Ia5JF4IU|IK5JF4IU|L6lTA+8GEtFuYqZXBJw7KPhaSNFuc6sCH8ciPeVDEMpkdaAOAJg/LPxeTNV0YKMFFYBnOaw6Gw==|LqpNau8UXMc7d/gfUNUufvoJRt0naOkURMQ5feYcU9Ivf/8GQqg+|LatTA+8GLfNWTpYqJbJOEItiSbcybugXR8Ana/AKQsApCOI=|LKpRAZQETMwydvIVNaBaEpRuIqVZFJRqJqdeXtk8d/YMQM4ze/8FTMw2f/sATqVMHJoMUrg=|K6tMa/4XR8Anbu4RVL4o|KqhPaP1iTrUhLftDTIwoJvVhLLleef8CR9wmb+t9LapNE4ZhL61eEZQCIw==|KalOafxjT7QgLPpCTY0pJ/RgLbhfEolwObZOC+F3|KKhPaP1iTrUhLftDTIwoJvVhLLleEolwNbVNAet9|N7dQd+J9Uao+MuRcU5M3Oep+M6ZBDZZvKqpSF/1r|NrZRduNiQaUPFcdpca8QXd4kae4VUNEuYe4WWcwrZv0EQcE+dpwK|NbdQd+ILW7dNCJNpLK07a+wLVcAnaO4VUNNFZA==|NLRTdOFgQ6cNF8Vrc60SX9wma+wXUtMsY+wUW84pZf4GS8w+dZ8J|M7NUc+ZnRL8bAN57RZ0ucOsRQcU/cvUOL8U=|MrBXcOVkR7MXD91fTYo0PNR2KLMjbO4JRMo0FY51JbBZCY13PrtIaYM=|MbFWceRlRr0ZAtx5R58scukSQsY8dfECI8k=|MLBXcOVkR7MXD91fTYo0PNR2KLNJGZ1nLq1VdJ4=|P71afegBUb1CDJdtKK44aO8IVsMka+0RVNJEZQ==|Pr5ZfutqSb0ZAdNRQ4Q6Mtp4Jr1GFpJoI61ffpQ=|Pb1afegBUdcwf/kKRsVTcg==|PLxbfOkAUNcwf/kLR8BWdw==|O7tce+5vTLgcBNZURoE/N999I7hCEpZsKa5Wd50=|OrleeewFVdAia/AKTs8oZ+IaUN5IaQ==|Obtce+5vTKgXCtN8YaQLNOxDWs8oD4p0MKtRGpp9M7BMHJpmKbJKAJtiJswrZ/wVAcRqcPoUWt43Z+MaXtkqC+E=|OLhfeO1sT7sfB9VXRYI8NNx+ILtAEJRtKa9Tcpg=|B4dgR9JTcJQrNu9AXZg3CNB/ZvMUWcI6dPsCTacx|BoZhRtNScZUqN+5BXJk2CdF+Z/IVWcI6dPsHQ6k/|BYViRdBRcoYiOuhqeL8BCeFDHYZ8LKhRFZpgQas=|BIZhRtNScZUqN+5BXJk2CdF+Z/IVMrdKApljKKhPAYJ+LqhUG4B4MqlQFP4ZVc4nM/ZYQsgmaOwFVdEuYucfPtQ=|A4NkQ9ZXdIAkPO5sfrkHD+dFG4B7K69QHJhgQas=|AoJlQtdWdZEuM+pFWJ0yDdV6Y/YRXMc/d/APQ6k/|AYFmQdRVdpItMOlGW54xDtZ5YPUSXsU9dfMIRa85|AIBnQNVUd4MnP+1vfboEDORGGIN5Ka1SH5hlRK4=|D41qTdgxYY1wO6BaHpwKWt06ZPEWWdgha+54WQ==|Do5pTttaeY0pMeNhc7QKAupIFo12JqJfEZFuT6U=|DY1qTdgxYecAT843c/BmRw==|DIxrTNkwYOcAT842f/5oSQ==|C4tsS95ffIgsNOZkdrEPB+9NE4hyIqZbFJVuT6U=|CotsS95ffIgsNOZkdrEPB+9NE4h1MapRAYV4PbNKa4E=|CYhvSN1cf4svN+VndbIMBOxOEItxO6BbC49zPb1BYIo=|CIluSdxdfoouNuRmdLMNBe1PEYp2OKNcDIh0O7tHZow=|F5ZxVsNCYZUxKft5a6wSGvJQDpVrJ7xHF5NgK6hSc5k=|FpdwV8JDYJQwKPp4aq0TG/NRD5RuJL9EFJBiL6tSc5k=|FZRzVMFAY5czK/l7aa4QGPBSDJdrIrlGFpJgLqxef5U=|FJRzVMFAY5czK/l7aa4QGPBSDJdsPL9FCItyU7k=|E5F2UcRFZoI8IvhaUrYJFNd1av8YP7pBCJNqIq07a+wLVcAnb+wWX9FHZg==|EpJ1UsdGZYE/IftZUbUKF9R2afwbVs0yevwATqQy|EZJpJb5FFZB3OrlDE5dpIrlHApllLLdNAINkKbJIAoViJ6BHCIdgLalOAYBnKKpNAoFmKa1KDpVtILtDD5RqOr9MHJllNbBXGZt8MrFWGJx7NbBXBoB5KbNMHJpoOL5NHZtnN7FMHIZ0JKJdDYtzI6VcDIpwILpACJNhMb5ZEol0JL5NHYd1Jb9FCZJ0Ob9YCY92JrxGCZJ0OaJECotsPbkv" });             model.Add(new PostParaPair() { Key = "umto", Value = "T7a1f5ec30a29c6b7e223b6872fb8637a" });

return model.ToString();         }     }

PostParaPair类的定义
public class PostParaPair
{
    List<PostParaPair> paraList = new List<PostParaPair>();
    public string Key { get; set; }
    public string Value { get; set; }
    public void Add(PostParaPair para)
    {
        paraList.Add(para);
    }
    public override string ToString()
    {
        string reString = "";
        if (paraList.Count != 0)
        {
            foreach (PostParaPair item in paraList)
            {
                reString += string.Format("&{0}={1}", item.Key, CommonMethod.GetUrlEncode(item.Value));
            }
        }
        return reString.TrimStart(‘&‘);
    }
}

CommonMethod.GetUrlEncode的定义:

public static string GetUrlEncode(string content)
    {
        return System.Web.HttpUtility.UrlEncode(content, System.Text.Encoding.UTF8);
    }

时间: 2024-08-15 01:21:11

天猫登录源码 POST C#的相关文章

Yii2 使用 QQ 和 Weibo 第三方登录源码

我们社区在 yii2-authclient 多次升级后,登录异常.一直想寻求一种通用的方法,尽量不重写 OAuth2, BaseOAuth 以及 OAuthToken 类, 所以本次直接在 initUserAttributes 方法返回结果的地方去修改,这样会受 yii2-authclient 升级影响较小,我把 QQClient.php 和 WeiboClient.php 放在 frontend/widgets 下了,接下来我们来看代码! QQClient.php 您的邮箱 [email pr

小米网站登录源码C#版

一步一步做,肯定能成功 HttpHelper类请从网络上搜索 string postData = getPostData(); HttpHelper ht = new HttpHelper(); HttpItem item = new HttpItem() { URL = "https://account.xiaomi.com/pass/serviceLoginAuth2", Method = "POST", Postdata = postData, CookieC

前端工程师开发APICloud应用源码集锦

现在APICloud开发者众多,各位前端开发者也可以利用自己擅长的技术来开发属于自己的APP,很多人会问,如何开发,下面就整理出来十款分享出来的源码给大家参考和学习: 仿QQ电影票源码 web前端开发者的尝试,仿炫酷的QQ电影票前端源码 http://community.apicloud.com/bbs/forum.php?mod=viewthread&tid=502 仿大众点评APP源码 测试apicloud的跨平台能力,仿大众点评APP前端源码 http://community.apiclo

C#源码500份

C#源码500份 C Sharp  短信发送平台源代码.rar http://1000eb.com/5c6vASP.NET+AJAX基础示例 视频教程 http://1000eb.com/89jcC# Winform qq弹窗 360弹窗 http://1000eb.com/89jf精华志 C#高级编程(第七版)源码 http://1000eb.com/89k3C#网络应用编程教案及代码.rar http://1000eb.com/89khIPhone远程桌面xp控制+Desktop+Conne

Shiro安全框架入门篇(登录验证实例详解与源码)

一.Shiro框架简单介绍 Apache Shiro是Java的一个安全框架,旨在简化身份验证和授权.Shiro在JavaSE和JavaEE项目中都可以使用.它主要用来处理身份认证,授权,企业会话管理和加密等.Shiro的具体功能点如下: (1)身份认证/登录,验证用户是不是拥有相应的身份: (2)授权,即权限验证,验证某个已认证的用户是否拥有某个权限:即判断用户是否能做事情,常见的如:验证某个用户是否拥有某个角色.或者细粒度的验证某个用户对某个资源是否具有某个权限: (3)会话管理,即用户登录

Asp.Net使用加密cookie代替session验证用户登录状态 源码分享

首先 session 和 cache 拥有各自的优势而存在.  他们的优劣就不在这里讨论了. 本实例仅存储用户id于用户名,对于多级权限的架构,可以自行修改增加权限字段   本实例采用vs2010编写,vb和c#的代码都是经过测试的:一些童鞋说代码有问题的 注意下    什么? 你还在用vs2008 vs2005? 请自行重载 带有 optional 标致的函数   童鞋们提到的 密码修改后 要失效的问题 当时没有想到 个人认为 大致方向可以> >1. 每个用户生成1个xml 里面保存随机的几

shiro登录模块源码分析

接触和使用shiro还是有好大一段时间,可惜并没有搞明白其实的原理和机制.因为工作中使用的框架都封装好了,so......并没有去研究. 原来一直猜想的是shiro可以直接连接数据库,验证用户名和密码.但是又没在实体类中找到有什么特殊的标记注解之类的. 就有点好奇了,于是趁这两天工作不是那么紧张了,就跟了下源码. 如有不对,请留言指正.蟹蟹! 红色部分是主要代码: UsernamePasswordToken token = new UsernamePasswordToken(user.getUs

Struts2+Spring+Ibatis用户注册、登录、管理入门学习实例源码下载

原文:Struts2+Spring+Ibatis用户注册.登录.管理入门学习实例源码下载 源代码下载地址:http://www.zuidaima.com/share/1550463735532544.htm Struts2+Spring+Ibatis用户注册.登录.管理入门学习实例源码下载 项目截图: jar包和sql文件都在源码包中. 运行截图: 用户注册页面: 用户管理页面:

基于sina微博官方sdk源码实现的微博授权登录和分享,以及获取信息

本菜近期由于工作需要,在大牛的要求下,用sina官方平台提供的SDk的源码(非静态库)实现了微博的授权登录,分享,并获取用户信息,好友信息,(包括昵称,头像,userID,token,等等)写完了之后对整体的体系,有了深刻的理解,希望对与本菜一样刚工作不久的新人朋友有所帮助,话休繁说,上代码. // 这个是Sina的sdk源码.(大牛提供) // 这个是现示登录按钮的界面,分享和获取好友信息的我也写在这个页面上了 // 这个是登录的验证界面(就是新浪的那个WebView) // 这个界面关键的代