現在WebページのURLパスを第2階層まで取得

パス

「http://xxxx.co.lp/together/14/19」ページで、URLパスの第2階層まで取得したい

 閲覧数:5132  投稿日:2019-11-19  更新日:2019-11-19  

< 最初に試したこと >
文字列操作
・「/」が現れる2番目までの位置を取得しようとした
→ 「最初の位置」は「strpos」を使用することで簡単に取得できるが、「2番目の位置」取得は予想以上に面倒なことが判明

・「/」が最初に現れる位置を最後から検索しようとした
→ 「strrpos」を探すも、そんな関数は存在しない
→ 「strpos」のoffsetパラメータで、 負の数を指定すると、文字列の末尾からこの数だけ戻った場所から検索を開始する
→ URL構成に左右されるため、汎用性は低い


< 採用案 >
・1.$_SERVER["REQUEST_URI"]で現在ページのURLパスを取得。(/together/14/19)
・2.explodeでスラッシュ区切りにし、配列$urlAryへ格納
Array(
[0] =>
[1] => together
[2] => 14
[3] => 19
)
・3.連結


コード

$urlAry = explode('/',$_SERVER["REQUEST_URI"]);
$result = '/'.$urlAry['1'].'/'.$urlAry['2']; //url第2階層まで
echo $result;



結果

/together/14



タグ


explode 





realpath(__DIR__)

現在URLのホスト名を取得



類似度ページランキング
順位 ページタイトル抜粋
1 現在WebページのURLパスを第2階層まで取得 100
2 現在URLのホスト名を取得 56
3 現在のセッション名を取得、表示 32
4 現在のセッション ID を取得 32
5 URLから、トップページ(index.html)判定 29
6 マークダウンで書かれたURLを(エスケープ処理するのではなく)削除する 28
7 配列のキーを取得する array_keys() 26
8 指定文字が2回目に出現する位置以降の文字列を取得 26
9 配列内よりランダムに要素(例えば画像URL)を取得 25
10 「1文字目」から「最初の指定文字」前までの文字列を取得 24
11 UNIXのタイムスタンプから日付(文字列)を取得後、「現在の年月日時分秒」を表示 … getdate() 24
12 現在のセッションクッキーのパラメータ情報を配列として返す 24
13 日付(文字列)から、指定時刻のUNIXタイムスタンプを取得 23
14 gethostbyaddr / IPアドレスからホスト名を取得 22
15 PHPで最後の「指定区切り文字」より後ろを取得 22
16 gethostbynamel / 指定したインターネットホスト名に対応するIPv4アドレスの配列を取得 22
17 URL抽出 21
18 2次元配列を指定キーでソートするuser定義関数 21
19 gethostbyname / インターネットホスト名に対応するIPv4アドレスを取得 21
20 マークダウンで「> 引用」を、HTMLエスケープ後、
へHTML変換
21
2025/3/10 23:09 更新
週間人気ページランキング / 3-3 → 3-9
順位 ページタイトル抜粋 アクセス数
1 後ろから3文字削除 / 「18:00:00」→「18:00」 | 文字列(テキスト処理) 7
2 指定文字列より前を取得 | 文字列(テキスト処理) 6
2 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す | 配列(型) 6
3 PHPで最後の「指定区切り文字」より後ろを取得 | 配列(型) 5
4 URLから、トップページ(index.html)判定 | ルーティング 4
4 8桁の生年月日数字を分解 | 文字列(テキスト処理) 4
5 「input type="datetime-local"」で受け取った文字列をハイフンへ変更 | 日付および時刻関連 2
5 Smartyのテンプレートにincludeしたファイルを表示 | Smarty(テンプレートエンジン) 2
5 配列の要素に特定の値が存在すれば、要素のキーを返す array_search() | 配列(型) 2
5 24時間以降の時刻を表示 / "02:30" → "26:30" | 日付および時刻関連 2
5 現在WebページのURLパスを第2階層まで取得 | パス 2
5 多次元配列の作成 | 多次元配列(型) 2
5 (データベースなどから取得した)多次元配列の値と、一次元配列を比較して、「一致」及び「増減」を返す | 配列(型) 2
5 「指定文字」直後から「指定文字」直前までの文字列を返す | マルチバイト文字列(テキスト処理) 2
6 time | タグ毎エントリー一覧 1
6 平均値、分散、標準偏差、学力偏差値を求める | 統計 1
6 MySQLi (MySQL) カテゴリー 1
6 array_multisort | タグ毎エントリー一覧 1
6 後ろから3文字取得 | 文字列(テキスト処理) 1
6 指定文字が2回目に出現する位置以降の文字列を取得 | 文字列(テキスト処理) 1
2025/3/10 1:02 更新