新・元地方の中規模印刷会社で苦悩するWebデザイナー改めWebディレクターの日記

自由な20代、窮屈な30代を経て、遂に40代になっちまったWebディレクター&パソコン講師の覚書と思う言(こと)。略称【ちほちゅう】

*

WordPressでコンテンツの一部(記事途中から等)だけに認証(閲覧制限)をかける方法

      2016/05/05

  • このエントリーをはてなブックマークに追加

まさか、当ブログにこのシステムを載せるとは思っていませんでした。
が、結構、際どいネタなどもやっているので、ここでひとつ、このシステムを導入したのは良かったかもしれません。

どんなシステムかというと、記事(コンテンツ)の一部をログインしていないと見れない状態にするシステムです。
ログインというのはWordPressのアカウントでのことになりますので、管理者アカウントしか存在しない当ブログなどでは、管理者としてログインしていないと該当の記事を読むことはできなくなるということです。

ただし、ゲストアカウント等を用意してそのアカウントをお伝えすることで一部の人にはお見せすることは可能にはなるんですけどね。

セキュリティ
鍵かけちゃいます!

スポンサーリンク
 

とっても簡単でした。

まずは、該当のテーマのfunctions.phpにソースを書き込みます。

テーマというのはWordPressのデザイン、外観等を司るテンプレートをひとまとめにしたものです。
多くはPHPファイルでできていて「wp-content」→「themes」に収まっています。
この中のfunctions.phpにスクリプトを書き込むわけです。

以下の手順でWordPress上で可能です。

  1. 「外観」→「テーマの編集」
    記事内アクセス制限01
  2. (編集したいテーマをプルダウンで選んで「選択」をクリック)←初期値がいま使っているテーマになっているはず。
    「テーマのための関数 functions.php」(どんなテーマにも必ずあるはずです)をクリック。
    記事内アクセス制限02
  3. ここに、以下のソースを書き込みます。末尾にでも書き込んでおけばいいと思います。
    function login_read_more($atts, $content = null) {
        if (is_user_logged_in() && !is_null( $content ) && !is_feed()) {
            return $content;
        } else {
            return 'ここは好きな言葉に変えられます';
        }
    }
    add_shortcode('auth', 'login_read_more');
  4. こんな感じですね。
    一応、わかりやすくコメント(記事途中から非公開)も付けてます。
    記事内アクセス制限03
  5. 最期に「ファイルを更新」をクリック。

これで、初期設定は完了。

そして、記事を書くときに表示させたくない部分を[auth]非表示部分[/auth]で囲みます。

具体的にはこんな感じです。

記事内アクセス制限04

ソース(テキスト)編集でなくてもOK。

ちなみに、上記タイトルにある[auth][/auth]をコピペしてもダメです。
ちゃんとした書き方をすると上記「[auth]非表示部分[/auth]」が消えてしまうので本来「[」と「]」であるべきところをそれぞれ全角の「[」、「]」に変えています。
角カッコは半角の角カッコ([])ですのでお間違いないように。

以上で完了です。

実際見た時はこんな感じ。

記事内アクセス制限05

本来、記事になっているところがプログラムで設定した「続きを読むにはログインしてね」になっています。

なお、管理アカウントでログインしているときはこうです。

記事内アクセス制限06

[autu]~[/auth]で囲んだ部分がちゃんと表示されて見れるようになります。
以上、非常に簡単ですね。

これで、全体を非公開にしなくても部分的に非公開にさせることができるようになりました。
前述のとおり、ゲストアカウントを用意して、ゲストでログインさせるようにすれば管理者以外の一般ユーザーでも見ることは可能になりますので、この辺りをうまく仕組み化してあげると、有料コンテンツなんてのもできちゃうかもしれません。

自分、そんなのやるつもりありませんから。

以下のサイトを参考にさせていただきました。
ありがとうございました!

情報源: WordPressでコンテンツの一部だけに認証をかける | Firegoby

プログラム作者さんはこういうの使うのアダルト系くらいかなぁなんて言ってましたが、アダルト系じゃなくてもこういうの需要あるんですよ。
過去にlivedoorブログの時は何回か似たようなことやってましたし。

そうか、その当時の記事もこれ使えばWordPress上でも完全再現できるのか。

いや、厳密にはログイン用アカウントも用意してあげないとだから無理ですね。
livedoorブログの時はmixiアカウントやオープンID等でもログイン、閲覧できましたから。

そこまでやろうとすると結構な工数かかっちゃうような気がしますねぇ。。ってか、可能なのか?

 - WordPress, セキュリティ , , , , , ,

アドセンス広告メイン

Message

メールアドレスが公開されることはありません。

  関連記事

no image
セキュリティはますます重要になってきます

なんとも凄い記事を二つほど見つけました。 □ウイルスバスターで有名なトレンドマイ …

no image
中国ハッカー集団がサイバー攻撃の噂(9/18追記)

ある筋から得た情報。明日18日(土)に中国ハッカー集団が日本国内のホームページに …

スパムのターゲットにされたので「Akismet」を導入した【WordPress】 #wp

WordPress(ワードプレス)で運営している「つぶくま」がコメントスパムのタ …

OpenSSLに脆弱性(セキュリティホール)のバグ。鍵のマークも信用出来ない

何かと、「インターネットで個人情報を入力する際は鍵のマークに注目しましょう。」と …

サイト誘導型スパムにご注意!!

最近、引っかかりそうになったスパムでMIXYを紹介しました。 またまた引っかかり …

no image
世界一安全なドメインは「.jp」、危険なドメインは「.com」

今まで、安いからと「.com」ばかり選んできましたが、やはり高いものにはそれなり …

今、一番怖いのはAndroid(アンドロイド)スマートフォン

来年はアンドロイダー(Androidスマホユーザー)になるべく計画を立てているの …

意図的?カメラ付き無線(Wi-Fi)バイブ「Siime Eye」でナニ映像ダダ漏れ

これ、バイブってあれだよね? 女子が気持ちよくなるために使うやつ。 そんなものに …

鍵のマークも信用できないかもしれない

ちょっと気になるニュースがあったので単独の記事として扱わせていただきました。 □ …

WordPress(ワードプレス)でサイトマップ「Google XML Sitemaps」 #wp

プロット・ファクトリーをWordPress(ワードプレス)化した際に、サイトマッ …