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 相关文章推荐
常用Extjs工具:Extjs.util.Format使用方法
Mar 22 Javascript
鼠标拖拽移动子窗体的JS实现
Feb 25 Javascript
Javascript节点关系实例分析
May 15 Javascript
javascript的变量、传值、传址、参数之间关系
Jul 26 Javascript
JS+CSS实现TreeMenu二级树形菜单完整实例
Sep 18 Javascript
Java中int与integer的区别(基本数据类型与引用数据类型)
Feb 19 Javascript
JavaScript实现父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序的方法
Mar 30 Javascript
Vue.js实战之组件的进阶
Apr 04 Javascript
Angularjs 实现移动端在线测评效果(推荐)
Apr 05 Javascript
VUE element-ui 写个复用Table组件的示例代码
Nov 18 Javascript
详解KOA2如何手写中间件(装饰器模式)
Oct 11 Javascript
vuex中遇到的坑,vuex数据改变,组件中页面不渲染操作
Nov 16 Javascript
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
剧场版动画《PSYCHO-PASS 3 FIRST INSPECTOR》3月27日日本上映!
2020/03/06 日漫
php intval的测试代码发现问题
2008/07/27 PHP
php auth_http类库进行身份效验
2009/03/19 PHP
phpMyAdmin自动登录和取消自动登录的配置方法
2014/05/12 PHP
php封装的数据库函数与用法示例【参考thinkPHP】
2016/11/08 PHP
php的4种常用运行方式详解
2016/12/22 PHP
PHP Socket网络操作类定义与用法示例
2017/08/30 PHP
PHP内存溢出优化代码详解
2021/02/26 PHP
[原创]js与自动伸缩图片 自动缩小图片的多浏览器兼容的方法总结
2007/03/12 Javascript
JQuery 操作Javascript对象和数组的工具函数小结
2010/01/22 Javascript
js 复制或插入Html的实现方法小结
2010/05/19 Javascript
如何使用jquery动态加载js,css文件实现代码
2013/04/03 Javascript
引入JS文件IE6报语法错误或缺少对象问题的解决方法
2014/01/09 Javascript
倒记时60刷新网页的js代码
2014/02/18 Javascript
TypeError document.getElementById(...) is null错误原因
2015/05/18 Javascript
js中判断变量类型函数typeof的用法总结
2016/08/09 Javascript
EasyUI 中combotree 默认不能选择父节点的实现方法
2016/11/07 Javascript
knockoutjs模板实现树形结构列表
2017/07/31 Javascript
vue源码学习之Object.defineProperty对象属性监听
2018/05/30 Javascript
基于Vue2-Calendar改进的日历组件(含中文使用说明)
2019/04/14 Javascript
新手简单了解vue
2019/05/29 Javascript
vue移动端城市三级联动组件使用详解
2019/07/26 Javascript
Python文件夹与文件的操作实现代码
2014/07/13 Python
Python requests发送post请求的一些疑点
2018/05/20 Python
Python动态导入模块的方法实例分析
2018/06/28 Python
对Python w和w+权限的区别详解
2019/01/23 Python
Python实战购物车项目的实现参考
2019/02/20 Python
python-jwt用户认证食用教学的实现方法
2021/01/19 Python
CSS3 linear-gradient线性渐变生成加号和减号的方法
2017/11/21 HTML / CSS
英国最受欢迎的在线隐形眼镜商店:VisionDirect.co.uk
2018/12/06 全球购物
橄榄树药房:OLIVEDA
2019/09/01 全球购物
法律专业自我鉴定
2013/10/03 职场文书
职员竞岗演讲稿
2014/05/14 职场文书
2015年数学教研工作总结
2015/07/22 职场文书
三十年同学聚会感言
2015/07/30 职场文书
大学副班长竞选稿
2015/11/21 职场文书