这周又是自己瞎搞的一周。继上一周的一键生成二维码,然后扫描二维码就会跳转到生成二维码的那个url。测试用的是百度的网址,所以扫描二维码后出现的就是百度首页,当我把url地址改成一段文字时,扫描出来的就是那段文字了。于是我就有了一个大胆的想法,我要扫面二维码然后跳转出来的是一张图片,这样我就可以把自己喜欢的图片全部变成二维码,这样把二维码用来做头像的话,别人可能会因为好奇然后点开二维码,识别二维码出现图片会不会觉得我很厉害。。当然,这个只能用来骗骗外行人,敲代码的都知道这个很容易实现的。其实最主要的是,我可以把自己想要收藏起来的图片全部变成二维码,到时候别人看到文件夹里面也只是会觉得是一堆二维码,就不会问来问去了。有想法了就开始行动。
首先,得要把图片变成一个URL,这样就需要把图片上传到服务器上,上传图片到服务器,上传文件到服务器有两种方法,一种是使用WebClient下的方法UploadFile,另一种是使用HttpWebRequest,
使用WebClient下的方法UploadFile非常简单,只有两行代码:
OpenFileDialog ofd = new OpenFileDialog(); //为对话框设置标题 ofd.Title = "请选择上传的图片"; //设置筛选的图片格式 ofd.Filter = "图片格式|*.jpg"; //设置是否允许多选 ofd.Multiselect = false; //如果你点了“确定”按钮 if (ofd.ShowDialog() == System.Windows.Forms.DialogResult.OK) { //获得文件的完整路径(包括名字后后缀) string filePath = ofd.FileName; WebClient myWebClient = new WebClient(); myWebClient.UploadFile("http://192.168.0.20:8019/WebForm1.aspx", "POST", filePath); }
因为要上传到服务器,所以要新建一个WebForm,在WebForm里面接收数据,代码也很简单,也只有两行:
foreach (string f in Request.Files.AllKeys) { HttpPostedFile file = Request.Files[f]; //获取数据 file.SaveAs(@"G:/IIS部署/上传图片/图片/" + file.FileName); //保存文件在服务器上的位置 }
用HttpWebRequest相对来说比较麻烦,要根据url获取数据还要接收返回的数据,代码是从网上扣下来的
int returnValue = 0; // 要上传的文件 FileStream fs = new FileStream(fileNamePath, FileMode.Open, FileAccess.Read); BinaryReader r = new BinaryReader(fs); //时间戳 string strBoundary = "----------" + DateTime.Now.Ticks.ToString("x"); byte[] boundaryBytes = Encoding.ASCII.GetBytes("\r\n--" + strBoundary + "\r\n"); //请求头部信息 StringBuilder sb = new StringBuilder(); sb.Append("--"); sb.Append(strBoundary); sb.Append("\r\n"); sb.Append("Content-Disposition: form-data; name=\""); sb.Append("file"); sb.Append("\"; filename=\""); sb.Append(saveName); sb.Append("\";"); sb.Append("\r\n"); sb.Append("Content-Type: "); sb.Append("application/octet-stream"); sb.Append("\r\n"); sb.Append("\r\n"); string strPostHeader = sb.ToString(); byte[] postHeaderBytes = Encoding.UTF8.GetBytes(strPostHeader); // 根据uri创建HttpWebRequest对象 HttpWebRequest httpReq = (HttpWebRequest)WebRequest.Create(new Uri(address)); httpReq.Method = "POST"; //对发送的数据不使用缓存 httpReq.UserAgent = "MSIE"; httpReq.AllowWriteStreamBuffering = false; //设置获得响应的超时时间(300秒) httpReq.Timeout = 300000; httpReq.ContentType = "multipart/form-data; boundary=" + strBoundary; long length = fs.Length + postHeaderBytes.Length + boundaryBytes.Length; long fileLength = fs.Length; httpReq.ContentLength = length; try { progressBar.Maximum = int.MaxValue; progressBar.Minimum = 0; progressBar.Value = 0; //每次上传4k int bufferLength = 4096; byte[] buffer = new byte[bufferLength]; //已上传的字节数 long offset = 0; //开始上传时间 DateTime startTime = DateTime.Now; int size = r.Read(buffer, 0, bufferLength); Stream postStream = httpReq.GetRequestStream(); //发送请求头部消息 postStream.Write(postHeaderBytes, 0, postHeaderBytes.Length); while (size > 0) { postStream.Write(buffer, 0, size); offset += size; progressBar.Value = (int)(offset * (int.MaxValue / length)); TimeSpan span = DateTime.Now - startTime; double second = span.TotalSeconds; lblTime.Text = "已用时:" + second.ToString("F2") + "秒"; if (second > 0.001) { lblSpeed.Text = "平均速度:" + (offset / 1024 / second).ToString("0.00") + "KB/秒"; } else { lblSpeed.Text = " 正在连接…"; } lblState.Text = "已上传:" + (offset * 100.0 / length).ToString("F2") + "%"; lblSize.Text = (offset / 1048576.0).ToString("F2") + "M/" + (fileLength / 1048576.0).ToString("F2") + "M"; Application.DoEvents(); size = r.Read(buffer, 0, bufferLength); } //添加尾部的时间戳 postStream.Write(boundaryBytes, 0, boundaryBytes.Length); postStream.Close(); //获取服务器端的响应 WebResponse webRespon = httpReq.GetResponse(); Stream s = webRespon.GetResponseStream(); //读取服务器端返回的消息 StreamReader sr = new StreamReader(s); String sReturnString = sr.ReadLine(); s.Close(); sr.Close(); if (sReturnString == "Success") { returnValue = 1; } else if (sReturnString == "Error") { returnValue = 0; } } catch(Exception ex) { WriteLog(ex); //returnValue = 0; } finally { fs.Close(); r.Close(); } return returnValue;
HttpWebRequest和WebResponse貌似很重要,可以从url里面取到数据。所以我就根据网上一篇博客,写了一个虚拟登录的功能,随便找一个网站然后注册登录,根据开发者按键F12得到该网站登录管理的url,但是在测试的时候一直报403的错误,百度了很多,但是还是不能测试成功,虽然测试没有成功,但是了解了通过HttpWebRequest获取URL数据的方法,看了好几个这样的代码例子,发现代码都是大同小异:
public string requestM(string uName,string passwd) { Demo fr = new Demo(); string text = string.Empty; HttpWebRequest request = null; WebResponse response = null; request = (HttpWebRequest)WebRequest.Create("http://i.yiche.com/ajax/Authenservice/login.ashx"); request.Method = "POST"; request.ContentType = "application/x-www-form-urlencoded; charset=UTF-8"; request.UserAgent = "Code Sample Web Client"; request.Credentials = CredentialCache.DefaultCredentials; request.UseDefaultCredentials = true; request.AllowAutoRedirect = true; request.PreAuthenticate = true; request.CookieContainer = new CookieContainer(); request.CookieContainer = container;//获取验证码时获取到的cookie会附加在这个容器里面 request.KeepAlive = true;//建立持久性连接 //request.UserAgent = "Code Sample Web Client"; //整理数据 string postData = string.Format("userName={0}&passwd={1}", uName, passwd); ASCIIEncoding encoding = new ASCIIEncoding(); byte[] bytepostData = encoding.GetBytes(postData); request.ContentLength = bytepostData.Length; //发送数据 using (Stream requestStm = request.GetRequestStream()) { requestStm.Write(bytepostData, 0, bytepostData.Length); } //响应 response = request.GetResponse(); using (Stream responseStm = response.GetResponseStream()) { StreamReader redStm = new StreamReader(responseStm, Encoding.UTF8); text = redStm.ReadToEnd(); } return text; }
通过HttpWebRequest获取url数据的方法差不多就是这样了。
图片是上传到服务器上了,而且也能在服务器上找到从本地上传上去的图片,怎么把图片变成一个可用的url呢?也很简单,格式就是http://服务器ip地址:端口号/文件所在位置。由这个url生成的二维码产生了,用微信扫描也能出现该图片,但是有一个很严重的问题,那就是这个二维码只能通过内网才能扫出图片,用外网的话没有数据。要通过映射才能让外网访问到。虽然服务器的映射地址有,但是端口号却无法拿到,所以自己弄得这个二维码就只能自己看看了。看来什么时候得自己去租一个阿里云了,不然以后好多项目都不能测试了。
下周又要去泉州出差了,其实我一直不知道我去泉州能干嘛,只是去提供电脑还有空调遥控器吗??上次去泉州一个礼拜,什么都没学到,只是在旁边看着他找bug然后再找下一个bug,代码改坏了我这边再发一个代码给他。而且一出差就是一整个礼拜,还这么频繁的出差。也许现在部门就我最闲吧。。确实也就我最闲了。
原文地址:https://www.cnblogs.com/cc1120/p/9090075.html