コピペ出来ないWebページをコピペ出来るようにするためには? 2017年

ブラウザ

目次一覧

 状態:-  閲覧数:2,320  投稿日:2017-02-18  更新日:2020-12-03
最初に結論 / Chrome拡張「Enable right click」/ JavaScriptで、右クリック禁止を解除します

「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成 / 既存JavaScriptコードをブックマークレット化するためには?/ その他


右クリック出来るのに、コピペ出来ないWebページ。2020 年


最初に結論 / Chrome拡張「Enable right click」/ JavaScriptで、右クリック禁止を解除します

 閲覧数:481 投稿日:2017-02-18 更新日:2020-12-03

最初に結論


Webページの右クリック禁止を解除する「Chrome拡張」をインストールしても、コピペ出来るようにはなるとは限りません。

コピペ出来ないWebページをコピペ出来るようにするためには?
コピペ出来るようにする「ブックマークレット (Bookmarklet)」を作成します。

ブックマークレット とは?
userがWebブラウザのブックマークなどから起動し、Webブラウザで簡単な処理を行う簡易的なプログラムのことです。

Chrome拡張「Enable right click」


実際に試してみた「Chrome拡張」は、「Enable right click」

バージョン
0.0.9

更新日
2015 年 4 月 24 日

内容
右クリックが無効になっているサイトで右クリックメニューを有効にする

実際に試してみて気が付いたこと
・「右クリック禁止解除」=「コピペ出来るようになる」ではありません。
・両者は異なる概念です。
・「右クリック禁止解除」することでソースコードから「コピペ出来る」ようになります」が、はっきり言って面倒です。
・もっと手軽にコピペしたい、と思いました。

JavaScriptで、右クリック禁止を解除します


Chromeブラウザ下部で開く「Chrome Developer Tools」Consoleパネルへ、JavaScriptコードをコピペして実行

// 入れ替えるイベントリスナ
var f = function(){ return true; };

// 書き換え対象のDOMイベント名
var evs = "beforecopy beforecut click contextmenu copy dragstart mousedown mouseup selectstart".split(" ");

// 書き換え対象のCSS属性名
var props = "userSelect MozUserSelect MsUserSelect WebkitUserSelect".split(" ");

// 1要素に対する書き換え操作
function replace_events( elem ){
 // イベント
 for( var i = 0; i < evs.length; i ++ ){
   elem[ "on" + evs[i] ] = f();
 }
 // CSS属性
 if(elem.style){
   for( var i = 0; i < props.length; i ++ ){
      elem.style[  props[i] ] = "";
   }
 }
}

// 全要素に対し
var elems = document.getElementsByTagName("*");
for(var i = 0; i < elems.length; i ++){
 replace_events( elems[i] );
}
replace_events( document );


参考
ClipboardEvent

感想
・このJavaScriptコードを、Chromeブラウザ下部で開く「Chrome Developer Tools」Consoleパネルへ毎回コピペして実行することは、面倒だと感じました。
・もっと手軽にコピペしたいと思いました。

「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成 / 既存JavaScriptコードをブックマークレット化するためには?/ その他

 閲覧数:381 投稿日:2017-02-18 更新日:2020-12-03

「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成


ブックマークレット とは?
userがWebブラウザのブックマークなどから起動し、Webブラウザで簡単な処理を行う簡易的なプログラムのことです。
具体的には、1 行で書かれたJavascriptコードのことです。

リンクボタンのリンク先として、次のように書くと、クリックしたときにこのプログラムが実行できます。
javascript:実際のjavascriptコード処理;

既存JavaScriptコードをブックマークレット化するためには?


1.コメント削除
Closure Compiler Service

2.JavaScriptのコードから行頭・行末のスペースと改行コードを取り除いて、ブックマークレットのアンカーを表示
ブックマークレット作成スクリプト
※事前にコメント削除しておかないと、正常動作しません。

3.Bookmarkletをボタンとして登録
ブックマークツールバーへ、リンクをドラッグ&ドロップで追加
※最初は意味が分かりませんでしたが、実際に試してみたら理解出来ました。

処理結果例


1.コメント削除
var f=function(){return!0},evs="beforecopy beforecut click contextmenu copy dragstart mousedown mouseup selectstart".split(" "),props=["userSelect","MozUserSelect","MsUserSelect","WebkitUserSelect"];function replace_events(b){for(var a=0;a<evs.length;a++)b["on"+evs[a]]=f();if(b.style)for(a=0;a<props.length;a++)b.style[props[a]]=""}for(var elems=document.getElementsByTagName("*"),i=0;i<elems.length;i++)replace_events(elems[i]);replace_events(document);


2.JavaScriptのコードから行頭・行末のスペースと改行コードを取り除いて、ブックマークレットのアンカーを表示
<a id="result_anchor" href='javascript:(function(){var f=function(){return!0},evs="beforecopy beforecut click contextmenu copy dragstart mousedown mouseup selectstart".split(" "),props=["userSelect","MozUserSelect","MsUserSelect","WebkitUserSelect"];function replace_events(b){for(var a=0;a<evs.length;a++)b["on"+evs[a]]=f();if(b.style)for(a=0;a<props.length;a++)b.style[props[a]]=""}for(var elems=document.getElementsByTagName("*"),i=0;i<elems.length;i++)replace_events(elems[i]);replace_events(document);})();'>コピペ</a>


その他


「Javascript」項目で「すべてのサイトに対してJavascriptの実行を許可しない」を選択し、完了をクリック

PDF
上記方法ではコピペ出来ません。
「テキストをコピーできないPDF」から「テキストをコピーする」ためには、「Chrome」で「印刷」選択後、保存


ブラウザ × レンダリング

右クリック出来るのに、コピペ出来ないWebページ。2020 年



類似度ページランキング
順位 ページタイトル抜粋
1 コピペ出来ないWebページをコピペ出来るようにするためには? 2017年 78
2 右クリック出来るのに、コピペ出来ないWebページ。2020 年 54
3 「ジョジョ顔メーカー1.1」を「Windows 10」で動作させるためには? 35
4 ページ内リンクの位置を微調整するためには、Negative margin を使用する 31
5 一つの要素に対して「id 属性値」を複数指定することは出来ない 30
6 FireBug クィック情報ボックスを表示しないようにする 28
7 Braveインストールしてみたけれども、全ての広告を必ず非表示に出来るわけではないみたい 28
8 「Webページへのリンク」をクリックした際、Chrome起動オプションを適用させるには、レジストリを書き換えるしかない 27
9 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない 27
10 Firefox 8.0 にしたら、Firebugタイトル部分の半角スペースに‌·が入るようになったので、メモ 27
11 Chromeをインストール出来ない 26
12 HTMLで「1つのタグにidを複数指定」は出来ない! 26
13 「DALL·E 2 - OpenAI」を使用してみた感想。2022 年 7 月 31 時点では、デザイン実務に耐えられるレベルではないと思いました。 25
14 複数CSSファイルを、PHPを利用して1ファイルにする。~ 2018年 25
15 borderプロパティでは、線のスタイル・太さ・色について上下左右バラバラの指定を一括することは出来ない 25
16 Chromeでリンク先ページを常に別タブで開くためには、「Ctrlキーを押しながらクリック」 24
17 「Google Chrome を起動後、100%の確率で3分以内に落ちる」場合は、アンインストール後インストールし直すしかない 24
18 お使いのコンピュータ ネットワークから通常と異なるトラフィックが検出されました 24
19 画面キャプチャ 2017 年 24
20 ページで使用されている「id名」「class名」をChromeで取得したい   24
2024/4/26 6:58 更新
週間人気ページランキング / 4-19 → 4-25
順位 ページタイトル抜粋 アクセス数
1 16進数カラーコード / 2進数 23
2 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 14
3 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 13
4 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 12
5 RGB ⇔ Lab | 色変換(色) 9
5 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 9
6 Design 0 8
6 血の色 / #b30000 / #360800 / #ff0000 | カラーコード(色) 8
7 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 6
8 「z-index」効果を打ち消すスタイルシートは、「z-index:auto;」 5
8 「Chrome拡張機能」開発中に遭遇したエラー | Chrome 拡張機能 5
9 max-width: 100%の効果を打ち消すには、max-width: none; | CSS 4
10 「line-height」効果を打ち消すスタイルシートは、「line-height:normal; 3
10 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 3
10 「群青色」「瑠璃色」「ウルトラマリンブルー」の違い 3
10 「bgcolor」「background-color」「background」の違い | CSS 3
11 HTML5でiframeスクロールバーを表示しない方法が不明 | HTML5(HTML) 2
11 「Midjourney」を使用してみた感想。2022 年 8 月 2 時点では、画像生成能力自体は素晴らしいと思いますが、UIが致命的に分かりづらかったです。 | AI画像生成 2
11 2進数 / Binary Number 2
11 鉄道会社毎のカラーコード | カラーコード(色) 2
2024/4/26 1:01 更新