クリーンアップ

このコミットが含まれているのは:
守矢諏訪子 2022-03-27 02:41:32 +09:00
コミット c3b251434c
12個のファイルの変更263行の追加239行の削除

ファイルの表示

@ -1,10 +1,10 @@
<?php <?php
// アプリ // アプリ
define('APP_NAME', 'LoliPHP'); define('APP_NAME', 'LoliPHP');
// データベース // データベース
define('DB_HOST', 'localhost'); define('DB_HOST', 'localhost');
define('DB_USER', ''); define('DB_USER', '');
define('DB_PASS', ''); define('DB_PASS', '');
define('DB_NAME', ''); define('DB_NAME', '');
?> ?>

ファイルの表示

@ -1,103 +1,12 @@
<?php <?php
require_once('config.php'); require_once('./helper/php8compat.php'); // PHP8を実行していない場合・If not running PHP8
require_once('./helper/debug.php'); // デバッガー・Debugger
// PHP8を実行していない場合 require_once('./helper/db.php'); // データベースエンジン・Database engine
if (!function_exists('str_starts_with')) { require_once('./helper/request.php'); // リクエスト・Request
function str_starts_with (string $haystack, string $needle): bool { require_once('./helper/upload.php'); // ファイルアップロード・File upload
return (string)$needle !== '' && strncmp($haystack, $needle, strlen($needle)) === 0; require_once('./helper/curl.php'); // CURL
} require_once('./helper/cookie.php'); // クッキー・Cookie
} require_once('./helper/mail.php'); // メール・Mail
require_once('./helper/session.php'); // セッション・Session
if (!function_exists('str_ends_with')) { require_once('./helper/hash.php'); // ハッシュ・Hash
function str_ends_with (string $haystack, string $needle): bool {
$needle_len = strlen($needle);
return ($needle_len === 0 || 0 === substr_compare($haystack, $needle, - $needle_len));
}
}
if (!function_exists('str_contains')) {
function str_contains (string $haystack, string $needle): bool {
return $needle !== '' && mb_strpos($haystack, $needle) !== false;
}
}
if (!function_exists('array_key_first')) {
function array_key_first (array $array): int|string|null {
if (!is_array($array) || empty($array)) return NULL;
return array_keys($array)[0];
}
}
if (!function_exists('array_key_last')) {
function array_key_last (array $array): int|string|null {
if (!is_array($array) || empty($array)) return NULL;
return array_keys($array)[count($array)-1];
}
}
// デバッガー
// Debugger
function dd ($val) {
echo '<pre>';
var_dump($val);
echo '</pre>';
die();
}
// データベースエンジン
// Database engine
require_once('helper/db.php');
// リクエスト
// Request
function request (string $name): array {
if (isset($_POST[$name])) {
return ['post' => htmlspecialchars($name)];
}
else if (isset($_GET[$name])) {
return ['get' => htmlspecialchars($name)];
}
else if (isset($_REQUEST[$name])) {
return ['request' => htmlspecialchars($name)];
}
return ['error' => ''];
}
function request_all (): array {
$res = [];
if (!empty($_POST)) {
$res['post'] = [];
foreach ($_POST as $k => $v) $res['post'][$k] = htmlspecialchars($v);
}
if (!empty($_GET)) {
$res['get'] = [];
foreach ($_GET as $k => $v) $res['get'][$k] = htmlspecialchars($v);
}
if (!empty($_REQUEST)) {
$res['request'] = [];
foreach ($_REQUEST as $k => $v) $res['request'][$k] = htmlspecialchars($v);
}
return $res;
}
// ファイルアップロード
function loliupload () {}
// CURL
function lolicurl () {}
// クッキー
function getcookie (string $name): array { return htmlspecialchars($_COOKIE[$name]); }
function getrawcookie (string $name): array { return $_COOKIE[$name]; }
// メール
function lolimail () {}
// セッション
// ハッシュ
?> ?>

9
helper/cookie.php ノーマルファイル
ファイルの表示

@ -0,0 +1,9 @@
<?php
function getcookie (string $name): array {
return htmlspecialchars($_COOKIE[$name]);
}
function getrawcookie (string $name): array {
return $_COOKIE[$name];
}
?>

3
helper/curl.php ノーマルファイル
ファイルの表示

@ -0,0 +1,3 @@
<?php
function lolicurl () {}
?>

ファイルの表示

@ -1,164 +1,164 @@
<?php <?php
/* val require_once('../config.php');
*
* select => ['var1', 'var2'...]
* insert|update|where => ['key1' => 'value1', 'key2' => 'value2'...]
* order => ['var', 'asc'|'desc']
* limit => int
* */
function lolidb (string $table, array $val, string $mode='select'): array|bool {
// モードは違う場合、やめる。If the mode is wrong, stop.
if ($mode != 'select' && $mode != 'one' && $mode != 'insert' && $mode != 'update' && $mode != 'delete') {
dd("モードは「select」、「one」、「insert」、「update」、「delete」です。\nMode should be \"select\", \"one\", \"insert\", \"update\", or \"delete\".");
return false;
}
// 順のチェック。Check order. /* val
if (isset($val['order'])) { *
// selectかoneじゃない場合。If not select or one. * select => ['var1', 'var2'...]
if ($mode !== 'select' || $mode !== 'one') { * insert|update|where => ['key1' => 'value1', 'key2' => 'value2'...]
dd("「order」は「select」又は「one」のみで使えます。\n\"order\" can only be used with \"select\" or \"one\"."); * order => ['var', 'asc'|'desc']
* limit => int
* */
function lolidb (string $table, array $val, string $mode='select'): array|bool {
// モードは違う場合、やめる。If the mode is wrong, stop.
if ($mode != 'select' && $mode != 'one' && $mode != 'insert' && $mode != 'update' && $mode != 'delete') {
dd("モードは「select」、「one」、「insert」、「update」、「delete」です。\nMode should be \"select\", \"one\", \"insert\", \"update\", or \"delete\".");
return false; return false;
} }
// 複数の場合。If multiple. // 順のチェック。Check order.
if (count($val['order'] > 1)) { if (isset($val['order'])) {
dd("複数「order」は未対応です。\nMultiple \"order\" is not yet supported."); // selectかoneじゃない場合。If not select or one.
return false; if ($mode !== 'select' || $mode !== 'one') {
dd("「order」は「select」又は「one」のみで使えます。\n\"order\" can only be used with \"select\" or \"one\".");
return false;
}
// 複数の場合。If multiple.
if (count($val['order'] > 1)) {
dd("複数「order」は未対応です。\nMultiple \"order\" is not yet supported.");
return false;
}
// ascかdescかどうか。Whether it's asc or desc.
foreach ($val['order'] as $k => $v) {
if ($v !== 'asc' && $v !== 'desc') {
dd("「order」は「asc」又は「desc」です。\n\"order\" should be \"asc\" or \"desc\".");
return false;
}
}
} }
// ascかdescかどうか。Whether it's asc or desc. // 限界のチェック。Check limit.
foreach ($val['order'] as $k => $v) { if (($mode === 'select' || $mode === 'one') && isset($val['limit'])) {
if ($v !== 'asc' && $v !== 'desc') { // oneの場合。If one.
dd("「order」は「asc」又は「desc」です。\n\"order\" should be \"asc\" or \"desc\"."); if ($mode === 'one') {
dd("「one」の場合、「limit」はいつでも「1」です。「limit」は1以上は必要の場合、「select」を使って下さい。\nIn case of \"one\", \"limit\" is always \"1\". If \"limit\" needs to be more than \"1\", please use \"select\".");
return false;
}
// selectじゃない場合。If not select.
else if ($mode !== 'select') {
dd("「insert」、「update」及び「delete」で、「limit」を使えません。\n\"limit\" cannot be used with \"insert\", \"update\", and \"delete\".");
return false; return false;
} }
} }
}
// 限界のチェック。Check limit. // insertの場合。In case of insert.
if (($mode === 'select' || $mode === 'one') && isset($val['limit'])) { if ($mode === 'insert' && !isset($val['insert'])) {
// oneの場合。If one. dd("「insert」モードの場合、「insert」値は必須です。\nIn case of \"insert\" mode, \"insert\" value is necessary.");
if ($mode === 'one') {
dd("「one」の場合、「limit」はいつでも「1」です。「limit」は1以上は必要の場合、「select」を使って下さい。\nIn case of \"one\", \"limit\" is always \"1\". If \"limit\" needs to be more than \"1\", please use \"select\".");
return false; return false;
} }
// selectじゃない場合。If not select. // updateの場合。In case of update.
else if ($mode !== 'select') { if ($mode === 'update' && !isset($val['update'])) {
dd("insert」、「update」及び「delete」で、「limit」を使えません。\n\"limit\" cannot be used with \"insert\", \"update\", and \"delete\"."); dd("update」モードの場合、「update」値は必須です。\nIn case of \"update\" mode, \"update\" value is necessary.");
return false; return false;
} }
}
// insertの場合。In case of insert. // MySQLiの創作。Creation of MySQLi.
if ($mode === 'insert' && !isset($val['insert'])) { $mysqli = mysqli_connect(DB_HOST, DB_USER, DB_PASS, DB_TABLE);
dd("「insert」モードの場合、「insert」値は必須です。\nIn case of \"insert\" mode, \"insert\" value is necessary."); $result = null;
return false;
}
// updateの場合。In case of update. if ($mode == 'select' || $mode == 'one') {
if ($mode === 'update' && !isset($val['update'])) { // select値がなければ、全部を選択する。If there is no select value, select everything.
dd("「update」モードの場合、「update」値は必須です。\nIn case of \"update\" mode, \"update\" value is necessary."); if (!isset($val['select'])) {
return false; $val['select'] = ['*'];
}
// MySQLiの創作。Creation of MySQLi.
$mysqli = mysqli_connect(DB_HOST, DB_USER, DB_PASS, DB_TABLE);
$result = null;
if ($mode == 'select' || $mode == 'one') {
// select値がなければ、全部を選択する。If there is no select value, select everything.
if (!isset($val['select'])) $val['select'] = ['*'];
$query = 'SELECT '.$val['select'].' FROM '.$table;
if (isset($val['where'])) {
$query .= ' WHERE ';
foreach ($val['where'] as $k => $v) {
$query .= $k.' = '.$v;
if ($k !== array_key_last($val['where'])) $query .= ' AND ';
} }
}
if (isset($val['order'])) { $query = 'SELECT '.$val['select'].' FROM '.$table;
$query .= ' ORDER BY ';
foreach ($val['order'] as $k => $v) { if (isset($val['where'])) {
$query .= $k; $query .= ' WHERE ';
$query .= ' '.strtoupper($v); foreach ($val['where'] as $k => $v) {
$query .= $k.' = '.$v;
if ($k !== array_key_last($val['where'])) $query .= ' AND ';
}
} }
}
if ($mode == 'one') $query .= ' LIMIT 1'; if (isset($val['order'])) {
$query .= ' ORDER BY ';
foreach ($val['order'] as $k => $v) {
$query .= $k;
$query .= ' '.strtoupper($v);
}
}
if ($mode == 'one') {
$query .= ' LIMIT 1';
}
else {
if (isset($val['limit'])) {
$query .= ' LIMIT '.(int)$val['limit'];
}
}
$result = mysqli_query($mysqli, $query.';');
$row = mysqli_fetch_assoc($result);
}
else { else {
if (isset($val['limit'])) $query .= ' LIMIT '.(int)$val['limit']; if ($mode == 'insert') {
} $query .= 'INSERT INTO '.$table.' (';
foreach ($val['insert'] as $k => $v) {
$result = mysqli_query($mysqli, $query.';'); $query .= $k;
$row = mysqli_fetch_assoc($result); if ($k !== array_key_last($val['insert'])) {
} $query .= ', ';
else { }
if ($mode == 'insert') { }
$query .= 'INSERT INTO '.$table.' ('; $query .= ') VALUES (';
foreach ($val['insert'] as $k => $v) { foreach ($val['insert'] as $k => $v) {
$query .= $k; $query .= $v;
if ($k !== array_key_last($val['insert'])) $query .= ', '; if ($k !== array_key_last($val['insert'])) {
$query .= ', ';
}
}
$query .= ')';
} }
$query .= ') VALUES ('; else if ($mode == 'update') {
foreach ($val['insert'] as $k => $v) { $query .= 'UPDATE '.$table.' SET ';
$query .= $v; foreach ($val['update'] as $k => $v) {
if ($k !== array_key_last($val['insert'])) $query .= ', ';
}
$query .= ')';
}
else if ($mode == 'update') {
$query .= 'UPDATE '.$table.' SET ';
foreach ($val['update'] as $k => $v) {
$query .= $k.' = '.$v;
if ($k !== array_key_last($val['update'])) $query .= ', ';
}
if (isset($val['where'])) {
$query .= ' WHERE ';
foreach ($val['where'] as $k => $v) {
$query .= $k.' = '.$v; $query .= $k.' = '.$v;
if ($k !== array_key_last($val['where'])) $query .= ' AND '; if ($k !== array_key_last($val['update'])) {
$query .= ', ';
}
}
if (isset($val['where'])) {
$query .= ' WHERE ';
foreach ($val['where'] as $k => $v) {
$query .= $k.' = '.$v;
if ($k !== array_key_last($val['where'])) {
$query .= ' AND ';
}
}
} }
} }
} else if ($mode == 'delete') {
else if ($mode == 'delete') { $query .= 'DELETE FROM '.$table;
$query .= 'DELETE FROM '.$table;
if (isset($val['where'])) { if (isset($val['where'])) {
$query .= ' WHERE '; $query .= ' WHERE ';
foreach ($val['where'] as $k => $v) { foreach ($val['where'] as $k => $v) {
$query .= $k.' = '.$v; $query .= $k.' = '.$v;
if ($k !== array_key_last($val['where'])) $query .= ' AND '; if ($k !== array_key_last($val['where'])) {
$query .= ' AND ';
}
}
} }
} }
$stmt = mysqli_prepare($mysqli, $query.';');
} }
$stmt = mysqli_prepare($mysqli, $query.';'); return $row;
} }
return $row;
}
function lolilog (string $val, string $mode='info'): bool {
if (!$file = fopen('./lolilog', 'a+')) {
dd('lolilogファイルを開けられません。');
return false;
}
$time = time();
$logtext = '['.date('Y-m-d H:i:s T', $time).' ('.$time.') - '.mb_strtoupper($mode)."]\n".$val."\n\n";
if (fwrite($file, $logtext) === false) {
dd('lolilogファイルに書き出しに失敗しました。');
return false;
}
fclose($file);
return true;
}
?> ?>

26
helper/debug.php ノーマルファイル
ファイルの表示

@ -0,0 +1,26 @@
<?php
function dd ($val) {
echo '<pre>';
var_dump($val);
echo '</pre>';
die();
}
function lolilog (string $val, string $mode='info'): bool {
if (!$file = fopen('./lolilog', 'a+')) {
dd('lolilogファイルを開けられません。');
return false;
}
$time = time();
$logtext = '['.date('Y-m-d H:i:s T', $time).' ('.$time.') - '.mb_strtoupper($mode)."]\n".$val."\n\n";
if (fwrite($file, $logtext) === false) {
dd('lolilogファイルに書き出しに失敗しました。');
return false;
}
fclose($file);
return true;
}
?>

2
helper/hash.php ノーマルファイル
ファイルの表示

@ -0,0 +1,2 @@
<?php
?>

3
helper/mail.php ノーマルファイル
ファイルの表示

@ -0,0 +1,3 @@
<?php
function lolimail () {}
?>

34
helper/php8compat.php ノーマルファイル
ファイルの表示

@ -0,0 +1,34 @@
<?php
if (!function_exists('str_starts_with')) {
function str_starts_with (string $haystack, string $needle): bool {
return (string)$needle !== '' && strncmp($haystack, $needle, strlen($needle)) === 0;
}
}
if (!function_exists('str_ends_with')) {
function str_ends_with (string $haystack, string $needle): bool {
$needle_len = strlen($needle);
return ($needle_len === 0 || 0 === substr_compare($haystack, $needle, - $needle_len));
}
}
if (!function_exists('str_contains')) {
function str_contains (string $haystack, string $needle): bool {
return $needle !== '' && mb_strpos($haystack, $needle) !== false;
}
}
if (!function_exists('array_key_first')) {
function array_key_first (array $array): int|string|null {
if (!is_array($array) || empty($array)) return NULL;
return array_keys($array)[0];
}
}
if (!function_exists('array_key_last')) {
function array_key_last (array $array): int|string|null {
if (!is_array($array) || empty($array)) return NULL;
return array_keys($array)[count($array)-1];
}
}
?>

33
helper/request.php ノーマルファイル
ファイルの表示

@ -0,0 +1,33 @@
<?php
function request (string $name): array {
if (isset($_POST[$name])) {
return ['post' => htmlspecialchars($name)];
}
else if (isset($_GET[$name])) {
return ['get' => htmlspecialchars($name)];
}
else if (isset($_REQUEST[$name])) {
return ['request' => htmlspecialchars($name)];
}
return ['error' => ''];
}
function request_all (): array {
$res = [];
if (!empty($_POST)) {
$res['post'] = [];
foreach ($_POST as $k => $v) $res['post'][$k] = htmlspecialchars($v);
}
if (!empty($_GET)) {
$res['get'] = [];
foreach ($_GET as $k => $v) $res['get'][$k] = htmlspecialchars($v);
}
if (!empty($_REQUEST)) {
$res['request'] = [];
foreach ($_REQUEST as $k => $v) $res['request'][$k] = htmlspecialchars($v);
}
return $res;
}
?>

2
helper/session.php ノーマルファイル
ファイルの表示

@ -0,0 +1,2 @@
<?php
?>

3
helper/upload.php ノーマルファイル
ファイルの表示

@ -0,0 +1,3 @@
<?php
function loliupload () {}
?>