Web前端开发之水印、图片验证码


Posted in Javascript onNovember 27, 2016

一、水印

1.画布

System.Drawing.Image img = System.Drawing.Image.FromStream(FileUpload1.FileContent);

2.创建绘制对象,告诉它往哪张图片上绘制

Graphics g = Graphics.FromImage(img);

3.绘制的内容

string s = www.itnba.com;

4.绘制的字体

Font f = new Font("黑体",130);

5.绘制的画刷

Brush b = new SolidBrush(Color.Red);

6.开始绘制

g.DrawString(s, f, b, 5, 5);

二、图片验证码

Bitmap bit = new Bitmap(90, 40);//画布大小
    Graphics g = Graphics.FromImage(bit);//创建绘制对象,告诉它往哪张图片上绘制
    Random r = new Random();
    string s = "";
    Color color1 = Color.FromArgb(r.Next(155, 255), r.Next(155, 255), r.Next(155, 255));
    g.FillRectangle(new SolidBrush(color1), 0, 0, 90, 40);//画布颜色随机
    for (int i = 0; i < 10; i++)//随机画干扰线
    {
      Color color3 = Color.FromArgb(r.Next(170, 255), r.Next(190, 255), r.Next(170, 255));
      Pen pp = new Pen(new SolidBrush(color3), r.Next(0, 5));
      g.DrawLine(pp, r.Next(0, 90), r.Next(0, 40), r.Next(0, 90), r.Next(0, 40));
    }
    string yan = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";//设置随机的验证码,从里面抽取
    int wei = 0;
    for (int i = 0; i < 4; i++)//取四位验证码,颜色随机
    {
      string m = yan.Substring(r.Next(0, yan.Length), 1);
      s += m;
      Color color2 = Color.FromArgb(r.Next(0, 155), r.Next(0, 155), r.Next(0, 155));
      int w = r.Next(20, 25);
      Font f = new Font("黑体", w);
      SolidBrush b = new SolidBrush(color2);
      g.DrawString(m, f, b, wei, r.Next(0, 10));
      wei += w;
    }
    Session["YZM"] = s;//把验证码保存到session中
    for (int i = 0; i < 251; i++)
    {
      Color color3 = Color.FromArgb(r.Next(0, 255), r.Next(0, 255), r.Next(0, 255));
      Pen pp = new Pen(new SolidBrush(color3), r.Next(0, 5));
      int a = r.Next(0, 90);
      int b = r.Next(0, 40);
      g.DrawLine(pp, a, b, (a + 1), (b + 1));
    }
    bit.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
    Response.End();

验证码:

<asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
    <asp:Image ID="Image1" runat="server" ImageUrl="Default2.aspx" />//这里图片路径不是一张图片的话会默认打开

以上所述是小编给大家分享的Web前端开发之水印、图片验证码,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript判断复选框是否选中的方法
Oct 16 Javascript
JS实现的仿淘宝交易倒计时效果
Nov 27 Javascript
Jquery Easyui日历组件Calender使用详解(23)
Dec 18 Javascript
自学实现angularjs依赖注入
Dec 20 Javascript
JS实现仿微信支付弹窗功能
Jun 25 Javascript
JS实现点击按钮可实现编辑功能
Jul 03 Javascript
vue-cli 引入jQuery,Bootstrap,popper的方法
Sep 03 jQuery
vue-cli项目代理proxyTable配置exclude的方法
Sep 20 Javascript
微信小程序带动画弹窗组件使用方法详解
Nov 27 Javascript
vue通过指令(directives)实现点击空白处收起下拉框
Dec 06 Javascript
Js数组扁平化实现方法代码总汇
Nov 11 Javascript
Vue中ref和$refs的介绍以及使用方法示例
Jan 11 Vue.js
jQuery时间日期三级联动(推荐)
Nov 27 #Javascript
Jquery 整理元素选取、常用方法一览表
Nov 26 #Javascript
jQuery插件扩展实例【添加回调函数】
Nov 26 #Javascript
JS扩展类,克隆对象与混合类实例分析
Nov 26 #Javascript
JS自定义混合Mixin函数示例
Nov 26 #Javascript
JS克隆,属性,数组,对象,函数实例分析
Nov 26 #Javascript
JS匿名函数类生成方式实例分析
Nov 26 #Javascript
You might like
php之字符串变相相减的代码
2007/03/19 PHP
php foreach 使用&amp;(与运算符)引用赋值要注意的问题
2010/02/16 PHP
PHP设计模式之结构模式的深入解析
2013/06/13 PHP
关于查看MSSQL 数据库 用户每个表 占用的空间大小
2013/06/21 PHP
PHP数据库连接mysql与mysqli对比分析
2016/01/04 PHP
yii2.0整合阿里云oss删除单个文件的方法
2017/09/19 PHP
学习ExtJS accordion布局
2009/10/08 Javascript
用JS写的一个TableView控件代码
2010/01/23 Javascript
js简单实现交换Li的值
2014/05/22 Javascript
PHP中使用微秒计算脚本执行时间例子
2014/11/19 Javascript
JS通过ajax动态读取xml文件内容的方法
2015/03/24 Javascript
JavaScript获得表单target属性的方法
2015/04/02 Javascript
AngularJS基础 ng-click 指令示例代码
2016/08/01 Javascript
javascript设计模式Constructor(构造器)模式
2016/08/19 Javascript
基于JavaScript实现右键菜单和拖拽功能
2016/11/28 Javascript
jQuey将序列化对象在前台显示地实现代码(方法总结)
2016/12/13 Javascript
EasyUI学习之Combobox下拉列表(1)
2016/12/29 Javascript
JS简单实现数组去重的方法示例
2017/03/27 Javascript
浅谈angularJS的$watch失效问题的解决方案
2017/08/11 Javascript
Node.js 多进程处理CPU密集任务的实现
2019/05/26 Javascript
es6中比较有用的7个技巧小结
2019/07/12 Javascript
使用Python脚本来获取Cisco设备信息的示例
2015/05/04 Python
Python中for循环控制语句用法实例
2015/06/02 Python
python使用pyqt写带界面工具的示例代码
2017/10/23 Python
Selenium元素的常用操作方法分析
2018/08/10 Python
美国新蛋IT数码商城:Newegg.com
2016/07/21 全球购物
德国富尔达运动鞋店:43einhalb
2020/12/25 全球购物
政风行风评议个人心得体会
2014/10/29 职场文书
2014年销售助理工作总结
2014/12/01 职场文书
先进单位申报材料
2014/12/25 职场文书
志愿者服务活动总结报告
2015/05/06 职场文书
捐款仪式主持词
2015/07/04 职场文书
酒店工程部的岗位职责汇总大全
2019/10/23 职场文书
万能密码的SQL注入漏洞其PHP环境搭建及防御手段
2021/09/04 SQL Server
HTTP中的Content-type详解
2022/01/18 HTML / CSS
如何通过一篇文章了解Python中的生成器
2022/04/02 Python