前端給網(wǎng)頁添加明水印的解決辦法

前端給網(wǎng)頁添加明水印的解決辦法

為了防止信息泄露习柠,保護(hù)版權(quán),在前端我們時(shí)常會(huì)用到水印照棋。

當(dāng)然资溃,水印也有明水印和暗水印之分,今天我們將的是前端實(shí)現(xiàn)明水印并實(shí)現(xiàn)全屏覆蓋烈炭。

創(chuàng)建一個(gè)水印圖層溶锭,我們需要兩步,一步是生成對(duì)應(yīng)的圖片符隙,第二步是把圖片放到最上層并全屏顯示趴捅,最好還是按照格子狀頁面上顯示多個(gè)水印內(nèi)容。

一膏执、生成圖片

因?yàn)椴煌撁娲笮〔煌な郏煌矸莸娜艘矐?yīng)該設(shè)置不同的水印信息露久。這就需要我們動(dòng)態(tài)生成圖片更米,這里就需要使用canvas

function createBackgroundImage(content, proportion, tiltAngle) {

? const can = document.createElement('canvas')

? can.width = document.body.clientWidth / proportion

? can.height = document.body.clientHeight / proportion

? const context = can.getContext('2d')

? context.rotate(-25 * Math.PI / 180);

? context.font = "800 30px Microsoft JhengHei";

? context.fillStyle = "#000";

? context.textAlign = 'center';

? context.textBaseline = 'Middle';

? context.fillText(content, 100, 100)


? return can.toDataURL("image/png")

? }

可以按照上面的方法創(chuàng)建canvas并填充文字。然后該函數(shù)返回一個(gè)對(duì)應(yīng)的圖片base64給我們毫痕。

這里需要注意一下該方法的入?yún)ⅲㄎ淖终髀停畛浔壤偌福瑑A斜角度)雖然是按照比例設(shè)置的cancas寬高,卻沒有在fillText上做處理栏笆,實(shí)際應(yīng)用的時(shí)候类腮,如果適配不同尺寸屏幕還是需要自己再寫一下的哈,同時(shí)還有文字的大小蛉加。

二蚜枢、水印布局

布局相對(duì)簡單一些,我們需要用到backgroundImage屬性

background-image 屬性為元素設(shè)置背景圖像针饥。

元素的背景占據(jù)了元素的全部尺寸厂抽,包括內(nèi)邊距和邊框,但不包括外邊距丁眼。

默認(rèn)地筷凤,背景圖像位于元素的左上角,并在水平和垂直方向上重復(fù)苞七。

之后藐守,我們只需要再頁面上添加一個(gè)div標(biāo)簽,并設(shè)置對(duì)應(yīng)的樣式蹂风,讓它占據(jù)全屏就行卢厂。

下面再給一個(gè)簡單示例

<!DOCTYPE html>

<html lang="en">

<head>

? <meta charset="UTF-8">

? <meta name="viewport" content="width=device-width, initial-scale=1.0">

? <meta http-equiv="X-UA-Compatible" content="ie=edge">

<title>Document</title>

? <style>

? \#content {

? width: 100%;

? height: 100vh;

? margin-left: auto;

? margin-right: auto;

? background: cadetblue;

? overflow: hidden;

? }

</style>

</head>

<body>

? <div id="content">

</div>

? <script>

? function createBackgroundImage(content, proportion, tiltAngle) {

? const can = document.createElement('canvas')

? can.width = document.body.clientWidth / proportion

? can.height = document.body.clientHeight / proportion

? console.log('can.width', can.width)

? console.log('can.height', can.height)

? const context = can.getContext('2d')

? context.rotate(-25 * Math.PI / 180);

? context.font = "800 30px Microsoft JhengHei";

? context.fillStyle = "#000";

? context.textAlign = 'center';

? context.textBaseline = 'Middle';

? context.fillText(content, 100, 100)

? return can.toDataURL("image/png")

? }

? const div = document.getElementById('content')

? console.log('div', div)

? div.style.backgroundImage = `url(${createBackgroundImage('伯約同學(xué)', 6, 10)})`

</script>

</body>

</html>

有興趣的可以直接復(fù)制上面的代碼看一下效果~

固然,稍微有點(diǎn)基礎(chǔ)的可以通過打開控制臺(tái)取消水印效果惠啄,這時(shí)候我們就需要監(jiān)聽dom的變化足淆,這個(gè)我們后續(xù)再專門講一下~

px:明水印畢竟防君子不防小人,下期我們就聊一聊暗水印是如何實(shí)現(xiàn)的礁阁。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末巧号,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子姥闭,更是在濱河造成了極大的恐慌丹鸿,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件棚品,死亡現(xiàn)場離奇詭異靠欢,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)铜跑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門门怪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人锅纺,你說我怎么就攤上這事掷空。” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵坦弟,是天一觀的道長护锤。 經(jīng)常有香客問我,道長酿傍,這世上最難降的妖魔是什么烙懦? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮赤炒,結(jié)果婚禮上氯析,老公的妹妹穿的比我還像新娘。我一直安慰自己莺褒,他們只是感情好魄鸦,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著癣朗,像睡著了一般拾因。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上旷余,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天绢记,我揣著相機(jī)與錄音,去河邊找鬼正卧。 笑死蠢熄,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的炉旷。 我是一名探鬼主播签孔,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼窘行!你這毒婦竟也來了饥追?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤罐盔,失蹤者是張志新(化名)和其女友劉穎但绕,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惶看,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡捏顺,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了纬黎。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片幅骄。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖本今,靈堂內(nèi)的尸體忽然破棺而出拆座,到底是詐尸還是另有隱情主巍,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布懂拾,位于F島的核電站煤禽,受9級(jí)特大地震影響铐达,放射性物質(zhì)發(fā)生泄漏岖赋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一瓮孙、第九天 我趴在偏房一處隱蔽的房頂上張望唐断。 院中可真熱鬧,春花似錦杭抠、人聲如沸脸甘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丹诀。三九已至,卻和暖如春翁垂,著一層夾襖步出監(jiān)牢的瞬間铆遭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工沿猜, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留枚荣,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓啼肩,卻偏偏與公主長得像橄妆,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子祈坠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • 導(dǎo)語:前段時(shí)間做某系統(tǒng)審核后臺(tái)害碾,出現(xiàn)了審核人員截圖把內(nèi)容外泄露的情況,雖然截圖內(nèi)容不是特別敏感赦拘,但是安全問題還是不...
    李亞_45be閱讀 1,180評(píng)論 0 0
  • 最近vue項(xiàng)目需要做一個(gè)水印功能蛮原,通過網(wǎng)上多種方式的的對(duì)比選擇了下面的方式: 在utils.js方法封裝如下: /...
    3bc9e2ff2ac3閱讀 492評(píng)論 0 0
  • 創(chuàng)建watermark.js文件 let watermark = {} let setWatermark = (s...
    51409fc99cdc閱讀 814評(píng)論 0 0
  • 代碼如下: function watermark(settings) { //默認(rèn)設(shè)置 var defau...
    smallThree1閱讀 6,618評(píng)論 0 0
  • 前段時(shí)間做某系統(tǒng)審核后臺(tái),出現(xiàn)了審核人員截圖把內(nèi)容外泄露的情況另绩,雖然截圖內(nèi)容不是特別敏感儒陨,但是安全問題還是不能忽視...
    貧僧夜夜闖青樓閱讀 583評(píng)論 0 0