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

ブラウザ

目次一覧

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

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


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


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

 閲覧数:177 投稿日: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コードをブックマークレット化するためには?/ その他

 閲覧数:149 投稿日: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ページ。2020 年 54
2 ページ内リンクの位置を微調整するためには、Negative margin を使用する 31
3 一つの要素に対して「id 属性値」を複数指定することは出来ない 30
4 FireBug クィック情報ボックスを表示しないようにする 28
5 Braveインストールしてみたけれども、全ての広告を必ず非表示に出来るわけではないみたい 28
6 「Webページへのリンク」をクリックした際、Chrome起動オプションを適用させるには、レジストリを書き換えるしかない 27
7 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない 27
8 Firefox 8.0 にしたら、Firebugタイトル部分の半角スペースに‌·が入るようになったので、メモ 27
9 Chromeをインストール出来ない 26
10 HTMLで「1つのタグにidを複数指定」は出来ない! 26
11 複数CSSファイルを、PHPを利用して1ファイルにする。~ 2018年 25
12 borderプロパティでは、線のスタイル・太さ・色について上下左右バラバラの指定を一括することは出来ない 25
13 Chromeでリンク先ページを常に別タブで開くためには、「Ctrlキーを押しながらクリック」 24
14 「Google Chrome を起動後、100%の確率で3分以内に落ちる」場合は、アンインストール後インストールし直すしかない 24
15 ページで使用されている「id名」「class名」をChromeで取得したい   24
16 お使いのコンピュータ ネットワークから通常と異なるトラフィックが検出されました 24
17 CSSキーフレームアニメーションで、マウスアウト時に独自のアニメーションを設定することは出来ない 24
18 Firefox7 「このサイトのパスワードを保存しますか?」を非表示にする(案) 24
19 「Twitter Bootstrap」2系のアイコンは、画像なので大きく出来ない 24
20 Google Chrome™ デベロッパーツールで表示できないスマホ画面を確認するためには、「mobile browser emulator」を使用 24
2021/8/02 8:26 更新
週間人気ページランキング / 7-26 → 8-1
順位 ページタイトル抜粋 アクセス数
1 画面キャプチャ | Chrome 拡張機能(ブラウザ) 51
2 RGB ⇔ Lab | 色変換(色) 46
3 血の色 / #b30000 / #360800 / #ff0000 | 色 31
4 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 25
5 RGBの種類 / ビットカラー | RGB(色) 24
6 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 23
7 「属性」「プロパティ」「アトリビュート」の違い | CSS 21
8 Design 0 20
9 「bgcolor」「background-color」「background」の違い | CSS 15
10 コズミックブルーが何色か分からない | 色 12
10 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 12
11 使用していないCSSをチェックする、標準的な方法を知りたい | CSS 11
11 HSLとHSVの違い | 色変換(色) 11
12 ページ内リンクの位置を微調整するためには、Negative margin を使用する | CSS 10
13 キャラクター無料着せ替えジェネレーター Rinmaru Games / オンラインサービス | イラスト素材(デザイン) 9
13 「Bootstrapデザイン」✕「グラフ」 | 2系(Bootstrap) 9
13 アドベンチャーゲーム系の素材をどうやって用意するの? | イラスト素材(デザイン) 9
13 キャラクター無料作成ジェネレーター / FLASH / オンラインサービス | イラスト参考(デザイン) 9
13 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 9
14 黒体 / 色温度 / D65(6500K)/ D50(5000K)/ K | 色 8
2021/8/2 1:01 更新