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

ブラウザ

目次一覧

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

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


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


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

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

 閲覧数:419 投稿日: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/11/23 5:21 更新
週間人気ページランキング / 11-16 → 11-22
順位 ページタイトル抜粋 アクセス数
1 鉄道会社毎のカラーコード | カラーコード(色) 12
2 FontAwesomeでアイコンが□(四角)になって表示されない Forbidden  | Font Awesome(フォント) 10
3 Design 0 8
3 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Chrome 拡張機能 8
4 血の色 / #b30000 / #360800 / #ff0000 | カラーコード(色) 6
5 「東京都」のカラーコード取得は難しい | カラーコード(色) 5
5 Fireworks で背景画像透明化 | Fireworks CS3(Fireworks) 5
6 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 4
7 「:after擬似要素」は、Chromeの「要素を検証」で確認できない | 擬似(CSS) 3
7 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 3
7 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 3
7 個人的によく見返すエントリーへのLinkなど | その他 3
7 RGB ⇔ Lab | 色変換(色) 3
7 「Google Chrome」の文字が突然ギザギザで表示されるようになったら、「chrome://flags/#top-chrome-md」へアクセス後、右上の「Reset all」ボタンをクリックします。 | Google Chrome(ブラウザ) 3
7 色モデルイメージ図 | 色変換(色) 3
8 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 2
8 ICCプロファイル | カラーマネージメント(色) 2
8 パッケージ化されてない拡張機能 | Chrome 拡張機能 2
8 空間的 / 可逆な JPEG ファイルの読み込みは実行されません | Photoshop CS3(Photoshop) 2
8 「overflow」効果を打ち消すスタイルシートは、「overflow: auto;」 2
2024/11/23 1:01 更新