日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

JavaScript 禁止用戶保存圖片的實現代碼

瀏覽:45日期:2023-06-21 13:56:18

添加事件禁止選擇、拖拽、右鍵(簡單的禁止用戶保存圖片,但無法阻止用戶打開控制臺查看,或是直接抓包)將之轉換為 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}/>

參考:https://www.jb51.net/article/185677.htm

將之轉換為 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) }}

useEffect(() => { const cancel1 = AntiDebug.cyclingDebugger() as any const cancel2 = AntiDebug.checkDebug(() => console.log(’請不要打開調試’), ) as any return () => { cancel1() cancel2() }}, [])return <img src={url} alt='' />

傳輸圖片使用自定義格式

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

到此這篇關于JavaScript 禁止用戶保存圖片的文章就介紹到這了,更多相關js 禁止保存圖片內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频一区二区三区在线| 男人操女人的视频在线观看欧美| 婷婷综合亚洲| 亚洲高清二区| 三上亚洲一区二区| 欧美aa一级| 免费毛片在线不卡| 欧美精品黄色| 日本精品久久| 久久中文欧美| 欧洲一级精品| 亚洲欧美日本日韩| 日韩国产精品久久久久久亚洲| 日韩精品三级| 美女久久久久久| 婷婷激情一区| 久久香蕉精品| 国产精品大片免费观看| 国产精品蜜芽在线观看| 国产色播av在线| 欧美/亚洲一区| 亚洲2区在线| 久久在线91| 亚洲一区成人| 麻豆一区二区三区| 亚洲一区亚洲| 国产精品国码视频| 亚洲免费精品| 精品精品99| 免费黄网站欧美| 久久伊人亚洲| 日韩中文字幕1| www.com.cn成人| 亚洲精品进入| 国产精品国产一区| 亚洲日韩视频| 国产综合激情| 久久久久九九精品影院| 美女久久一区| 久久久亚洲一区| 狂野欧美性猛交xxxx| 少妇精品在线| 中国女人久久久| 日韩综合在线| 91免费精品| 精品国产亚洲日本| 国产亚洲精aa在线看| 久久成人一区| 久久久久久久久丰满| 日韩精彩视频在线观看| 精品一区欧美| 在线国产一区二区| 日韩免费视频| 日韩88av| 麻豆国产精品777777在线| 奇米狠狠一区二区三区| 国产亚洲一级| 91精品91| 国产高清一区二区| 久久亚洲国产| av一区二区高清| 欧洲精品一区二区三区| 日韩国产一区二区| 日韩在线第七页| 黄色aa久久| 91看片一区| 1024精品一区二区三区| 99精品视频在线| 欧美特黄一级| 中文字幕一区二区三区日韩精品 | 国产一区二区三区探花| 国产精品色婷婷在线观看| 久久精品凹凸全集| 日本不卡视频在线观看| 亚洲精品影视| 日本成人在线网站| 国产伦精品一区二区三区视频| 欧美日韩1区| 老牛国内精品亚洲成av人片| 中文字幕在线免费观看视频| 国产高清一区二区| 一二三区精品| 久久爱www成人| 久久蜜桃精品| 久久精品1区| 视频一区免费在线观看| 亚洲免费毛片| 国产在线日韩精品| 亚洲天堂1区| 亚洲欧美日韩国产一区二区| 国产精品中文字幕制服诱惑| 99精品视频精品精品视频| 亚洲一区二区三区在线免费| 老牛国内精品亚洲成av人片| 日韩在线观看不卡| 日本欧美在线| 一区二区三区四区在线看| 日韩在线视频一区二区三区| 国产精品久久久久av电视剧| 日韩和欧美的一区| av一区二区高清| 精品久久电影| 日韩有吗在线观看| 天堂√8在线中文| 亚洲午夜久久| 在线观看精品| 国产日韩欧美中文在线| 婷婷久久一区| 黑人精品一区| 国产精品亲子伦av一区二区三区| 蜜桃tv一区二区三区| 国产精品入口久久| 蜜臀av一区二区在线免费观看| 伊人久久在线| 久久精品一区二区三区中文字幕| 日韩制服丝袜av| 五月天激情综合网| 日韩在线观看不卡| 国产一区二区三区免费在线 | 色婷婷亚洲mv天堂mv在影片| 日韩激情中文字幕| 亚洲免费影院| 亚洲免费精品| 电影亚洲精品噜噜在线观看| 精品国产乱码久久久| 国产毛片一区二区三区| 亚洲日本在线观看视频| 视频在线观看一区| 久久亚洲欧美| 涩涩涩久久久成人精品| 男女激情视频一区| 亚洲天堂日韩在线| 亚洲欧美日本国产| 亚洲精品四区| 日韩一区二区三区高清在线观看 | 日韩中文字幕区一区有砖一区| 亚洲一区欧美二区| 一本一道久久a久久| 亚洲精品日本| 久久精品资源| 99成人超碰| 亚洲人亚洲人色久| 国产精品分类| 久久天堂精品| 五月激激激综合网色播| 日韩高清二区| 日韩免费高清| 亚洲视频二区| 精品亚洲成人| 五月婷婷亚洲| 国产欧美日韩精品一区二区免费 | 国产伦精品一区二区三区在线播放| 国产欧美日韩影院| 成人欧美一区二区三区的电影| 91久久久久| 牛牛精品成人免费视频| 欧美亚洲日本精品| 亚洲少妇一区| 国产激情综合| 午夜在线精品| 国产精品成人a在线观看| 红桃视频亚洲| 精品国产一区二区三区2021| 国产视频久久| 色在线中文字幕| 亚洲日本三级| japanese国产精品| 精品九九在线| 中文字幕一区二区av| 日本一区二区高清不卡| 综合国产精品| 国产亚洲高清视频| 日产精品一区二区| 欧美一级一区| 亚洲不卡视频| 午夜在线精品| 久久久国产精品一区二区中文| 91麻豆精品| 蜜臀av一区二区在线免费观看| 天堂√中文最新版在线| 久久av网址| 欧美日韩国产一区二区在线观看| 亚洲欧美久久久| 亚洲综合电影一区二区三区| 久久视频精品| 欧美~级网站不卡| 欧美午夜精彩| av中文字幕在线观看第一页 | 福利一区和二区| 老司机精品在线| 国产精品极品在线观看| 日本午夜免费一区二区| 日韩av电影一区| 日韩欧美久久| 日本不卡视频在线观看 | 日韩电影在线视频| 日韩免费福利视频| 日韩中文首页| 日韩毛片在线| 欧美日韩国产高清电影|