2018/5/21~2018/5/25 周记

这周又是自己瞎搞的一周。继上一周的一键生成二维码,然后扫描二维码就会跳转到生成二维码的那个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

时间: 2024-10-08 18:43:07

2018/5/21~2018/5/25 周记的相关文章

2018.8.21 2018暑假集训之滑雪

这个题原来做过 结果现在忘了 再来一遍 试题描述 LYH喜欢滑雪,因为滑雪的确很刺激,可是为了获得速度,滑的区域必须向下倾斜,当LYH滑到坡底,不得不再次走上坡或等着直升机来载他,LYH想知道在一个区域中最长的滑坡.滑坡的长度由滑过点的个数来计算,区域由一个二维数组给出,数组的每个数字代表点的高度.下面是一个例子: 1     2     3     4     5 16    17    18    19    6 15    24    25    20    7 14    23    2

三级菜单-2018.2.21

根据老男孩课程以及网上的代码,自行打出的代码,虽然参照的比较多,嘿嘿嘿 #_author_:"Bushii" #data:2018/2/21 menu= { '山东' : { '青岛' : ['四方','黄岛','崂山','李沧','城阳'], '济南' : ['历城','槐荫','高新','长青','章丘'], '烟台' : ['龙口','莱山','牟平','蓬莱','招远'] }, '江苏' : { '苏州' : ['沧浪','相城','平江','吴中','昆山'], '南京' :

2018/7/21 Python 爬虫学习

2018/7/21,这几天整理出来的一些Python 爬虫学习代码. import urllib2 response = urllib2.urlopen("http://baidu.com") html = response.read() print html 进一步,可以request import urllib2 req = urllib2.Request("http://www.baidu.com") response = urllib2.urlopen(re

2018/8/21 qbxt测试

2018/8/21 qbxt测试 期望得分:0? 实际得分:0 思路:manacher   会写模板但是不会用 qwq 听了某人的鬼话,直接输出0,然后就gg了 #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> using namespace std; const int N = (int)2e6 + 10; typedef long long ll;

[cnbeta]iPhone 2018年全球出货2.25亿部:中国区下滑两成

iPhone 2018年全球出货2.25亿部:中国区下滑两成 2019年01月22日 20:12 501 次阅读 稿源:快科技 0 条评论 https://www.cnbeta.com/articles/tech/811379.htm 苹果iPhone近来的颓势有目共睹,尤其是作为核心增长引擎的中国区表现乏力,库克都频频"吐槽",另一方面又不得不调整措施,连续祭出了以旧换新.全面降价.密集广告等措施.今天,市调机构旭日大数据公布了苹果iPhone 2018年的统计报告,中国区的萎靡十分

Microsoft Artificial Intelligence Conference(2018.05.21)

时间:2018.05.21地点:北京嘉丽大酒店 原文地址:https://www.cnblogs.com/xuefeng1982/p/10335943.html

2018 1.21测试

套路 文件名:road.cpp(pas) 时间限制:1s 空间限制:512MB 题目描述: 给出1个 N 个点的有向图,每个点的出度恰好为一. 现在希望给这 N 条边重定向,求图中不出现环的方案数(对 109 + 7 取模). 输入格式: 第一行一个正整数 N. 第二行 N 个正整数 Xi,表示存在一条有向边 i 指向 Xi. 输出格式: 一行,一个整数 Ans,表示定向后不出现环的方案数. 样例读入: 5 2 3 1 5 4 样例输出: 12 数据范围: 对于 30% 的数据,保证 N 20 

摘一些重要的字符串方法(2018.2.21)

#摘一些重要的字符串方法 # print(st.count('t')) # print(st.startswith('d'))#判断是否以某个字符串开头 # print(st.center(50,' '))#居中 # print(st.find('t'))#查找到一个元素,并将索引值返回 # print(st.format(name='bushi',age=18)) #格式化输出的另一种方式 # print('My title'.lower())#全转化成小写 # print('my title

2018.2.21 Python 初学习

折腾了一天,一直在用CMD学习Python写Hello World.偶然间发现可以用Pycharm.也算是给后面想学习的人提个醒,方便省事许多. format()使用方法. age = 20name = 'Swaroop'print('{0} was {1} years old when he wrote this book'.format(name, age))print('Why is {0} playing with that python?'.format(name)) # 对于浮点数