使用Javascript实现网页水印(非图片水印)

常见的就是公文系统、合同系统等。
大家常常关注的是网站图片增加水印,而很少关注页面水印。
刚去G
【菜科解读】
在一些B/S结构的应用系统中,有很多页面是需要有水印的。
常见的就是公文系统、合同系统等。
大家常常关注的是网站图片增加水印,而很少关注页面水印。
刚去Google了一圈,关于页面水印的文章的数量为几乎为0. 本文中,流牛木马就与大家一起交流一下有关制作网页水印的心得。
本文讨论以下的情形: 新增水印的方法需要用Javascript完成,并要求能够方便地加入到原有的页面中,不能影响到已有的功能。
1.2 预期目标
就图片水印实现方案来说,我们预期至少包括以下几个目标:
1. 实现悬浮、半透明的图片水印
2. 包含水印的页面,所有元素均为只读(不可写)
3. 在包含框架页面中,可以控制任意一个子页面或父页面的水印生成
4. 在页面放大、缩小(resize过程)后,需要在保证页面不刷新的前提下,重新生成适应页面大小的新水印,以保证所有内容都被水印覆盖,并且不会因水印图片范围过大而产生滚动条。
5. 支持IE6\7\8浏览器。
暂不考虑其他浏览器。
1.3 效果图
加密前:
加密后:
可以打开附件里的文件进行查看。
2 实现步骤2.1 基本构思
加密的过程是一个Javascript函数执行过程,所以我们首先应该考虑用Javascript操作DOM对象的方式。
在已有的HTML页面中,新建一个DOM对象在Body节点下。
该对象的长、宽均经过计算,保证在覆盖全部页面内容的同时又不产生滚动条。
将该对象覆盖到原有的页面之上,设置背景图,并设置为透明。
创建新DOM元素:
使用document对象里的createElement方法。
创建元素后,设置它的z-index为一个大整数,保证它能够比已有网页的最大z-index大,才能完成 覆盖 。
计算新对象大小:
利用三个DOM对象值: clientWidth 、scrollHeight与clientHeight.
网页中一般不会出现横向滚动条,故不使用scrollWidth.
而纵向的滚动条就很常见了。
为了保证页面内容全部覆盖,在未出现滚动条的时候,使用clientHeight,出现滚动条后,则使用scrollHeight。
设置透明:
利用Alpha值。
Alpha是IE支持的css filter。
2.2 应变细节
有一个小细节是很有意思的,前文也提过了,就是resize的过程。
试想,当一个页面打开的时候是550px 400px,那么自然会生成550px 400px大小的水印。
但当用户对它进行最大化时,页面没有刷新,不会重新执行生成水印的函数,那么以前生产的水印图片就太小了。
如下图所示的情况。
请注意,它的右侧、下侧都是没有水印的。
为了应对这种情况,我们就需要对body的onresize()函数进行处理。
如果以前定义没有onresize()函数,则直接添加onresize();如果以前有onresize()函数,则对之进行修改。
2.3 最终代码
考虑到框架页面需要考虑的情况,该方法包括三个参数: 目标页面对象、目标页面字符串、 背景图片。
function GetWaterMarked(targetObj,jpgUrl,targetStr ) {
var windowobj=targetObj;
var waterMarkPicUrl=jpgUrl;
var controlWindowStr=targetStr;
if(windowobj.document.getElementById("waterMark") != null)
return;
var m = "waterMark";
var newMark = windowobj.document.createElement("div");
newMark.id = m;
newMark.style.position = "absolute";
newMark.style.zIndex = "9527";
newMark.style.top = "0px";
newMark.style.left = "0px";
newMark.style.width = windowobj.document.body.clientWidth;
if( parseInt(windowobj.document.body.scrollHeight) > parseInt(windowobj.document.body.clientHeight) )
{
newMark.style.height = windowobj.document.body.scrollHeight;
}else
{
newMark.style.height = windowobj.document.body.clientHeight;
}
newMark.style.backgroundImage = "url("+ waterMarkPicUrl +")";
newMark.style.filter = "alpha(opacity=50)";
windowobj.document.body.appendChild(newMark);
var markStr = "var sobj ="+controlWindowStr+".document.getElementById('waterMark');sobj.style.width ="+controlWindowStr+".document.body.clientWidth;sobj.style.height ="+controlWindowStr+".document.body.clientHeight;";
if(windowobj.document.body.onresize != null)
{
var oldResiae = windowobj.document.body.onresize.toString();
var oldResiaeStr = oldResiae.substr(oldResiae.indexOf("{")+1);
var oldResiaeStr= oldResiaeStr.substr(0,oldResiaeStr.lastIndexOf("}"));
oldResiaeStr+=";"+markStr;
windowobj.document.body.onresize = new Function(oldResiaeStr);
}
else
{
windowobj.document.body.onresize = new Function(markStr);
}
}
3 原有页面处理需要在原有的标签处加入一个onload方法。
如:
4 附件http://files.cnblogs.com/azure/%E6%B0%B4%E5%8D%B0.rar
_________________________________________________________________________________
关于扩展到非IE浏览器:
有很多朋友问起如何扩展到非IE浏览器。
我文中有提到设置水印图片透明的方式,那是一种仅适用于IE的方式。
要在其他浏览器中的设置图片透明,也是很容易的。
我还没有做测试,请各位看官自行参考这篇帖子:
http://dancewithnet.com/2009/09/06/css-opacity/
使用,Javascript,实现,网页,水印,非,图片,概述社保卡里的凭证到底如何给家人使用
具体操作步骤如下:社会保险服务个人网页自助办理:登陆个人网页,进入社保业务办理-医疗业务办理-个人账户家庭共享-新增绑定,输入亲属社保电脑号、亲属身份证号及亲属关系,提交保存,即完成绑定。
到社保分局医疗保险窗口申请办理:在社保部门医保现金报销窗口刷卡绑定,刷被使用人的社保卡,并录入使用人的社保卡号。
在定点医院医疗保险办公室办理:在医院医保办,通过“网上医院”刷卡绑定,刷被使用人的卡,并录入使用人的社保卡号。
完成绑定后,家人在就医时就可以使用社保卡里的余额进行支付了。
二、电子社保卡亲情服务此外,还可以通过电子社保卡的亲情服务功能,为家人提供便捷的电子社保卡签发和应用服务。
具体步骤如下:打开电子社保卡首页,点击右上角“我的”-“亲情服务”。
点击“添加”,验证电子社保卡密码后,阅读并同意添加亲情账户告知书。
输入要开通人的姓名、社保号码、亲情关系,点击“添加亲情账户”并上传身份凭证(小于16岁需同时上传人脸正面照)。
亲情服务绑定对象进行人脸识别操作,认证通过后则开通亲情服务成功。
通过电子社保卡亲情服务,可以帮家人查询个人社保权益单、进行社保待遇资格认证、办理社保网上转移申请等,同时也可以使用社保卡里的余额。
需要注意的是,社保卡里的余额属于个人所有,给家人使用时需确保符合要求,不得进行违法违规操作。
另外,不同地区的社保卡使用可能有所不同,具体操作方法还需根据当地而定。
交社保有啥好处?养老保险:为退休后的生活提供基本的经济保险,确保在年老失去劳动能力时能够获得稳定的养老金,维持一定的生活水平。
工伤保险:职工发生工伤时,工伤保险可用于支付工伤医疗费用、生活护理费、伤残补助以及伤残津贴,为职工提供全面的工伤保险。
失业保险:失业人员符合下列条件的,从失业保险基金中领取失业保险金:(一)失业前用人单位和本人已经缴纳失业保险费满一年的;(二)非因本人意愿中断就业的;(三)已经进行失业登记,并有求职要求的。
失业人员在领取失业保险金期间,参加职工基本医疗保险,享受基本医疗保险待遇。
失业人员应当缴纳的基本医疗保险费从失业保险基金中支付,个人不缴纳基本医疗保险费。
生育保险:用人单位已经缴纳生育保险费的,其职工享受生育保险待遇;职工未就业配偶按照相关法律享受生育医疗费用待遇。
医疗保险:就是指生病了医疗费用可以报销。
由单位和职工共同缴费。
累计缴纳医疗保险满一定年限(大部分城市为男25年、女20年),退休后不用再继续缴纳,也可以享受终身医疗保险待遇。
目前首批开通个人账户跨省家庭共济的地区(统筹区)有哪些?1、江苏省(苏州市)2、重庆市(云阳县)3、安徽省(淮南市)4、四川省(省本级、成都市、广安市)5、湖北省(襄阳市、黄冈市、咸宁市、随州市、恩施土家族苗族自治州、潜江市)6、河南省(郑州市、信阳市)7、河北省(石家庄市、唐山市、秦皇岛市、邯郸市、邢台市、保定市、张家口市、承德市、沧州市、廊坊市、衡水市、辛集市、定州市、雄安新区、省本级)8、甘肃省(临夏回族自治州)9、山东省(德州市)共31个地区(统筹区)已开通个人账户跨省共济使用。
广西南宁社保卡里的余额如何共用给家人使用
基数以上年职工月平均工资,或以新参加工作职工的第一个月工资。
广西南宁社保卡怎么供给家里人使用随新社通小编来了解一下:广西南宁社保卡里的余额如何共用给家人使用社保卡里的余额怎么给家人使用社保卡里的余额给家人使用,主要可以通过以下几种方式实现:一、社保卡绑定家人通过社保卡的家庭共享功能,可以将社保卡的余额绑定给家人使用。
具体操作步骤如下:社会保险服务个人网页自助办理:登陆个人网页,进入社保业务办理-医疗业务办理-个人账户家庭共享-新增绑定,输入亲属社保电脑号、亲属身份证号及亲属关系,提交保存,即完成绑定。
到社保分局医疗保险窗口申请办理:在社保部门医保现金报销窗口刷卡绑定,刷被使用人的社保卡,并录入使用人的社保卡号。
在定点医院医疗保险办公室办理:在医院医保办,通过“网上医院”刷卡绑定,刷被使用人的卡,并录入使用人的社保卡号。
完成绑定后,家人在就医时就可以使用社保卡里的余额进行支付了。
二、电子社保卡亲情服务此外,还可以通过电子社保卡的亲情服务功能,为家人提供便捷的电子社保卡签发和应用服务。
具体步骤如下:打开电子社保卡首页,点击右上角“我的”-“亲情服务”。
点击“添加”,验证电子社保卡密码后,阅读并同意添加亲情账户告知书。
输入要开通人的姓名、社保号码、亲情关系,点击“添加亲情账户”并上传身份凭证(小于16岁需同时上传人脸正面照)。
亲情服务绑定对象进行人脸识别操作,认证通过后则开通亲情服务成功。
通过电子社保卡亲情服务,可以帮家人查询个人社保权益单、进行社保待遇资格认证、办理社保网上转移申请等,同时也可以使用社保卡里的余额。
需要注意的是,社保卡里的余额属于个人所有,给家人使用时需确保符合要求,不得进行违法违规操作。
另外,不同地区的社保卡使用可能有所不同,具体操作方法还需根据当地而定。
目前首批开通个人账户跨省家庭共济的地区(统筹区)有哪些?1、重庆市(云阳县)2、湖北省(襄阳市、黄冈市、咸宁市、随州市、恩施土家族苗族自治州、潜江市)3、河北省(石家庄市、唐山市、秦皇岛市、邯郸市、邢台市、保定市、张家口市、承德市、沧州市、廊坊市、衡水市、辛集市、定州市、雄安新区、省本级)4、江苏省(苏州市)5、安徽省(淮南市)6、河南省(郑州市、信阳市)7、甘肃省(临夏回族自治州)8、山东省(德州市)9、四川省(省本级、成都市、广安市)共31个地区(统筹区)已开通个人账户跨省共济使用。
广西南宁的农村社保可以报销吗?农村社保卡报销比例是多少第1点,农村社保卡报销的比例介绍:农村社保卡报销比例:大病医疗门诊统筹乡、村补助比例65%、75%;一级医疗机构住院费用在400元以下者,不设起付线,二级医疗机构补助比例提高到75%-80%;三级医疗机构补助比例提高到55%-60%;省三级医疗机构补助比例提高到55%。
第2点,农村社保卡报销的比例介绍:农村社保卡异地就医报销比例:乡镇卫生院就医,起付线为100元,报销比例为90%;县级定点医院就医,起付线为200元,报销比例为82%;市级定点医院就医,起付线为500元,那么报销比例为65%;省级定点医院就医,起付线为700元,报销比例为55%;省外非定点医院就医,起付线为1000元,报销比例为45%。
第3点,农村社保卡报销的比例介绍:法律依据:参保人员在协议医疗机构发生的医疗费用,符合基本医疗保险药品目录、诊疗项目、医疗服务设施标准的,按基本医疗保险基金中支付。
参保人员确需急诊、抢救的,可以在非协议医疗机构就医;因抢救必须使用的药品可以适当放宽范围。
参保人员急诊、抢救的医疗服务具体管理由统筹地区根据当地实际情况制定。