成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

JavaScript 如何禁止用戶保存圖片

瀏覽:94日期:2023-10-08 08:20:00

場景

在業務需求中不希望用戶保存圖片,因為是一些供內部使用的圖片。

思路

添加事件禁止選擇、拖拽、右鍵(簡單的禁止用戶保存圖片,但無法阻止用戶打開控制臺查看,或是直接抓包) 將之轉換為 canvas(讓瀏覽器認為不是圖片以此禁止用戶對之進行圖片的操作,但無法阻止抓包) 禁止用戶使用控制臺查看源碼(阻止瀏覽器打開控制臺,但無法阻止抓包) 傳輸圖片使用自定義格式(可以阻止抓包,但需要后臺配合)

注:以下內容使用 react+ts 實現

添加事件禁止選擇、拖拽、右鍵

簡而言之,這是一種簡單有效的方式,能夠在用戶不打開控制臺的情況下阻止用戶保存圖片。

export function preventDefaultListener(e: any) { e.preventDefault()};<img src={props.url} alt='' style={{ //禁止用戶選擇 userSelect: ’none’, //禁止所有鼠標事件,過于強大,圖片僅用于展示可用 // pointerEvents: ’none’, }} onTouchStart={preventDefaultListener} onContextMenu={preventDefaultListener} onDragStart={preventDefaultListener}/>

將之轉換為 canvas

另一種思路是將圖片轉換為 canvas 避免用戶使用 img 相關的操作。

將圖片轉成 canvas

export async function imageToCanvas(url: string, canvas: HTMLCanvasElement) { return new Promise((resolve, reject) => { //新建Image對象,引入當前目錄下的圖片 const img = new Image() img.src = url const c = canvas.getContext(’2d’)! //圖片初始化完成后調用 img.onload = function () { //將canvas的寬高設置為圖像的寬高 canvas.width = img.width canvas.height = img.height //canvas畫圖片 c.drawImage(img, 0, 0, img.width, img.height) resolve() } img.addEventListener(’error’, (e) => { reject(e) }) })}

禁用 canvas 事件

const throwFn = () => { throw new Error( 'Uncaught DOMException: Failed to execute ’toDataURL’ on ’HTMLCanvasElement’: Tainted canvases may not be exported.', )}const $canvasRef = useRef<HTMLCanvasElement>(null) useEffect(() => { ;(async () => { await imageToCanvas(props.url, $canvasRef.current!) $canvasRef.current!.toBlob = throwFn $canvasRef.current!.toDataURL = throwFn })() }, []) return ( <canvas ref={$canvasRef} onTouchStart={preventDefaultListener} onContextMenu={preventDefaultListener} /> )

禁止用戶使用控制臺查看源碼

如果能禁止用戶操作控制臺,那么自然能夠避免用戶查看源碼了,下面是一個簡單的實現。

/** * 兼容異步函數的返回值 * @param res 返回值 * @param callback 同步/異步結果的回調函數 * @typeparam T 處理參數的類型,如果是 Promise 類型,則取出其泛型類型 * @typeparam Param 處理參數具體的類型,如果是 Promise 類型,則指定為原類型 * @typeparam R 返回值具體的類型,如果是 Promise 類型,則指定為 Promise 類型,否則為原類型 * @returns 處理后的結果,如果是同步的,則返回結果是同步的,否則為異步的 */export function compatibleAsync<T = any, Param = T | Promise<T>, R = T>( res: Param, callback: (r: T) => R,): Param extends Promise<T> ? Promise<R> : R { return (res instanceof Promise ? res.then(callback) : callback(res as any)) as any}/** * 測試函數的執行時間 * 注:如果函數返回 Promise,則該函數也會返回 Promise,否則直接返回執行時間 * @param fn 需要測試的函數 * @returns 執行的毫秒數 */export function timing<R>( fn: (...args: any[]) => R, // 函數返回類型是 Promise 的話,則返回 Promise<number>,否則返回 number): R extends Promise<any> ? Promise<number> : number { const begin = performance.now() const res = fn() return compatibleAsync(res, () => performance.now() - begin)}/** * 禁止他人調試網站相關方法的集合對象 */export class AntiDebug { /** * 不停循環 debugger 防止有人調試代碼 * @returns 取消函數 */ public static cyclingDebugger(): Function { const res = setInterval(() => { debugger }, 100) return () => clearInterval(res) } /** * 檢查是否正在 debugger 并調用回調函數 * @param fn 回調函數,默認為重載頁面 * @returns 取消函數 */ public static checkDebug( fn: Function = () => window.location.reload(), ): Function { const res = setInterval(() => { const diff = timing(() => { debugger }) if (diff > 500) { console.log(diff) fn() } }, 1000) return () => clearInterval(res) }}

傳輸圖片使用自定義格式

該功能需要服務端配合,故而此處贊不實現,可以參考 微信讀書,就是將文本轉為 canvas,數據傳輸也進行了加密,可以在很大程度上防止普通用戶想要復制/下載的行為了。

總結

如同所有的前端限制用戶的技術一樣,這是一個沒有終點的斗爭。。。

以上就是JavaScript 如何禁止用戶保存圖片的詳細內容,更多關于JavaScript 禁止保存圖片的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲精品欧美| 丁香天五香天堂综合| 国产精品午夜在线| 污片在线观看一区二区 | 亚洲一区二区三区美女| 免费成人av资源网| av一区二区三区| 久久久国产精品一区二区中文| 26uuu另类欧美| 免费观看日韩av| 国产精品国产三级国产专区53| 欧美在线小视频| 亚洲男人的天堂一区二区| 国产福利一区在线观看| 亚洲国产精品久久久久婷婷老年 | 波多野结衣在线一区| 一区二区视频欧美| 日韩一区二区精品| 五月天视频一区| 欧美国产先锋| 制服丝袜av成人在线看| 亚洲成人资源网| 欧美午夜免费影院| 在线播放国产精品二区一二区四区 | 91麻豆蜜桃一区二区三区| 色久优优欧美色久优优| 中文字幕欧美激情一区| 国产精品77777竹菊影视小说| 久久99伊人| 国产精品短视频| 成人激情小说乱人伦| 欧美丝袜丝nylons| 夜夜嗨av一区二区三区网页| 欧美在线免费一级片| 色偷偷久久一区二区三区| 中文字幕一区二区在线观看| 97久久超碰国产精品电影| 制服丝袜中文字幕一区| 青青草精品视频| 国产欧美日韩亚洲| 国产精品日产欧美久久久久| 不卡视频在线观看| 欧美美女直播网站| 秋霞午夜鲁丝一区二区老狼| 亚洲欧美久久久| 亚洲天堂免费在线观看视频| 色综合久久综合网97色综合| 日韩美女一区二区三区四区| 蜜臀91精品一区二区三区| 国产亚洲毛片| 一区二区三区电影在线播| 伊大人香蕉综合8在线视| 国产亚洲一本大道中文在线| 国产成人在线网站| 欧美日本一区二区| 午夜精品久久久久久久久久久| 伊人蜜桃色噜噜激情综合| 中文字幕 久热精品 视频在线 | 久久99久久99小草精品免视看| 久久久久久精| 亚洲国产精品欧美一二99| 最新成人av网站| 亚洲欧美色图小说| 影音先锋久久资源网| 国产婷婷一区二区| 色综合中文综合网| 91在线视频观看| 国产日韩欧美一区二区三区综合| 国产成人小视频| 日韩免费视频一区| 成人sese在线| 欧美成人bangbros| 成人午夜在线视频| 久久婷婷成人综合色| 91亚洲精品久久久蜜桃| 久久久久国产成人精品亚洲午夜| 99综合影院在线| 日本一区二区不卡视频| 91丨九色丨黑人外教| 久久久久久久电影| 91视频观看视频| 国产精品免费av| 日韩亚洲视频在线| 亚洲一区二区三区免费视频| 色呦呦国产精品| 免费观看在线综合色| 欧美日韩国产大片| 国产精品综合一区二区三区| 日韩免费观看2025年上映的电影| 91原创在线视频| **性色生活片久久毛片| 国产情侣久久| 日韩精品1区2区3区| 欧美最猛黑人xxxxx猛交| 麻豆视频一区二区| 日韩欧美激情四射| 午夜久久99| 亚洲精品视频一区| 亚洲欧美日韩国产综合精品二区 | 午夜久久久久久久久| 6080日韩午夜伦伦午夜伦| 精品福利av| 国产一本一道久久香蕉| 中文字幕一区二区三区精华液| 欧美在线观看你懂的| 欧美fxxxxxx另类| 日日夜夜免费精品| 国产视频一区在线观看| 在线观看一区日韩| 欧美日韩一区二区高清| 久久精品72免费观看| 国产精品色一区二区三区| 欧美三级韩国三级日本三斤 | 国产精品第十页| 精品无人区卡一卡二卡三乱码免费卡| 国产精品色婷婷| 欧美一区二区三级| 久久久精品日韩| 国产自产精品| 国产一区三区三区| 亚洲国产色一区| 亚洲国产精华液网站w| 欧美精品在线观看播放| 一本色道88久久加勒比精品| zzijzzij亚洲日本少妇熟睡| 日日夜夜精品视频免费| 中文字幕一区在线观看视频| 欧美成人在线直播| 91福利小视频| 91久久综合| 91在线观看美女| 九九国产精品视频| 一区二区成人在线观看| 国产午夜一区二区三区| 欧美视频一区在线| 亚洲三级毛片| 91麻豆自制传媒国产之光| 久久成人精品无人区| 亚洲精品视频一区| 国产三级欧美三级| 91麻豆精品国产自产在线| 亚洲一区激情| 欧美日韩一视频区二区| 成人免费视频播放| 精品无人码麻豆乱码1区2区 | 久久国产成人| 亚洲三级色网| 欧美日韩一区在线播放| 波多野结衣精品在线| 国精产品一区一区三区mba视频| 日日摸夜夜添夜夜添精品视频 | 久久久精品天堂| 欧美一级夜夜爽| 日本精品免费观看高清观看| 一区二区三区四区五区视频| 欧美精品三区| 成人avav影音| 国产一区二区影院| 蜜桃视频免费观看一区| 亚洲在线观看免费视频| 国产精品毛片久久久久久久| 精品久久久网站| 亚洲一区三区视频在线观看| 欧美性色综合| 欧美在线看片| 99久久99久久精品国产片果冻| 国产成a人无v码亚洲福利| 久久av资源站| 日本视频在线一区| 亚洲一区视频在线| 亚洲人成电影网站色mp4| 亚洲国产精品t66y| 国产日韩v精品一区二区| 精品99久久久久久| 日韩精品一区二| 884aa四虎影成人精品一区| 欧美日韩一区二区三区四区| 欧美亚洲国产怡红院影院| 色诱亚洲精品久久久久久| 久久深夜福利| 老司机免费视频久久 | 精品美女一区二区| 日韩一区二区三区电影 | 亚洲va欧美va国产va天堂影院| 一区av在线播放| 亚洲午夜免费福利视频| 亚洲国产日产av| 亚洲国产成人av好男人在线观看| 亚洲一区二区视频在线观看| 亚洲制服欧美中文字幕中文字幕| 亚洲永久免费视频| 午夜av区久久| 捆绑调教美女网站视频一区| 加勒比av一区二区| 国产九色sp调教91| 成人影视亚洲图片在线| a在线欧美一区| 欧美伊人影院| 亚洲东热激情| 欧美中文日韩|