* Add feed widget * add feed render * Add CommentPage widget * New theme (#1390) * 调整忽略目录 * add theme * fix theme scss build Co-authored-by: fen <f3nb0x@gmail.com> * s/is_writeable/is_writable/g * New upgrade method * merge new fixes from master * add pgsql ssl mode support (ref #1600) (#1623) * Feat/code refactor (#1626) * remove all magic methods, add type for class properties * refactor codes * fix all * refactor code * fix type * fix all * fix request is method * fix all * fix router * fix get page * fix 1.3.0 upgrade * [feat] support high resolution avatar * fix types in i18n component * Implement Ctrl+S or Command+S for save draft (#1628) * Implement Ctrl+S or Command+S for save draft * rename * add Typecho.savePost * fix upload file size * add new uploader * replace new uploader * fix textarea change * fix preview * refactor post edit * fix issue * fix page edit --------- Co-authored-by: joyqi <joyqi@segmentfault.com> Co-authored-by: joyqi <magike.net@gmail.com> * fix #1632 * Add svg to image types * Feat/tree pages (#1646) * add tree trait * finish category tree trait * support select fields * fix select fields * refactor admin trait * fix draft status * Add new contents type "revision" * minor refactor * add more tree view abstracts * add tree trait to pages * get ready for tree view pages * improve page edit * fix revision * fix slug * add router params delegate * fix params delegate * fix * fix * fix all * fix all * fix tree * fix page link * fix feed * fix page * fix permalink * fix permalink input * fix offset query * Support IDN (#1629) * Support IDN * use js * Optimize code * Optimize code * fix URL script * remove unnecessary use --------- Co-authored-by: joyqi <joyqi@segmentfault.com> * fix input element * fix #1651, close #1653 * Use json instead of serialize (#1624) * Use json instead of serialize * Fix Upgrade code * add tree trait * finish category tree trait * support select fields * fix select fields * refactor admin trait * fix draft status * Add new contents type "revision" * minor refactor * add more tree view abstracts * add tree trait to pages * get ready for tree view pages * improve page edit * fix revision * fix slug * add router params delegate * fix params delegate * fix * fix * fix all * fix all * fix tree * fix page link * fix feed * fix page * fix permalink * fix permalink input * fix offset query * Fix typo * remove proxy methods * remove unnecessary useage --------- Co-authored-by: joyqi <joyqi@segmentfault.com> Co-authored-by: joyqi <magike.net@gmail.com> * Fix Prevent XSS vulnerability in default theme (#1654) * Fix Prevent XSS vulnerability in default theme * Update var/Typecho/Db/Adapter/Pdo.php * fix the getter --------- Co-authored-by: joyqi <joyqi@segmentfault.com> * add throwCallback to widget response * fix: cut down fields when selecting recent posts * fix typo errors * fix typo errors * fix http client cookie * add throw finish * fix theme lang * fix default theme * fix query * add open graph and twitter card support add canonical link * fix canonical link meta * fix theme classic-22 * remove unnecessary scss file when packaging * init plugin signal * improve: remove feather-icon js file * fix: typo * improve: post detail layout * fix tags saving * improve: nav search * fix: theme screenshot * fix: theme page layout * remove php 7.2/7.3 env --------- Co-authored-by: fen <f3nb0x@gmail.com> Co-authored-by: Lu Fei <52o@qq52o.cn>
171 lines
3.4 KiB
PHP
171 lines
3.4 KiB
PHP
<?php
|
|
|
|
namespace Typecho;
|
|
|
|
/**
|
|
* cookie支持
|
|
*
|
|
* @author qining
|
|
* @category typecho
|
|
* @package Cookie
|
|
*/
|
|
class Cookie
|
|
{
|
|
/**
|
|
* 前缀
|
|
*
|
|
* @var string
|
|
* @access private
|
|
*/
|
|
private static string $prefix = '';
|
|
|
|
/**
|
|
* 路径
|
|
*
|
|
* @var string
|
|
* @access private
|
|
*/
|
|
private static string $path = '/';
|
|
|
|
/**
|
|
* @var string
|
|
* @access private
|
|
*/
|
|
private static string $domain = '';
|
|
|
|
/**
|
|
* @var bool
|
|
* @access private
|
|
*/
|
|
private static bool $secure = false;
|
|
|
|
/**
|
|
* @var bool
|
|
* @access private
|
|
*/
|
|
private static bool $httponly = false;
|
|
|
|
/**
|
|
* 获取前缀
|
|
*
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public static function getPrefix(): string
|
|
{
|
|
return self::$prefix;
|
|
}
|
|
|
|
/**
|
|
* 设置前缀
|
|
*
|
|
* @param string $url
|
|
*
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public static function setPrefix(string $url)
|
|
{
|
|
self::$prefix = md5($url);
|
|
$parsed = parse_url($url);
|
|
|
|
self::$domain = $parsed['host'];
|
|
/** 在路径后面强制加上斜杠 */
|
|
self::$path = empty($parsed['path']) ? '/' : Common::url(null, $parsed['path']);
|
|
}
|
|
|
|
/**
|
|
* 获取目录
|
|
*
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public static function getPath(): string
|
|
{
|
|
return self::$path;
|
|
}
|
|
|
|
/**
|
|
* @access public
|
|
* @return string
|
|
*/
|
|
public static function getDomain(): string
|
|
{
|
|
return self::$domain;
|
|
}
|
|
|
|
/**
|
|
* @access public
|
|
* @return bool
|
|
*/
|
|
public static function getSecure(): bool
|
|
{
|
|
return self::$secure ?: false;
|
|
}
|
|
|
|
/**
|
|
* 设置额外的选项
|
|
*
|
|
* @param array $options
|
|
* @return void
|
|
*/
|
|
public static function setOptions(array $options)
|
|
{
|
|
self::$domain = $options['domain'] ?: self::$domain;
|
|
self::$secure = !!$options['secure'];
|
|
self::$httponly = !!$options['httponly'];
|
|
}
|
|
|
|
/**
|
|
* 获取指定的COOKIE值
|
|
*
|
|
* @param string $key 指定的参数
|
|
* @param string|null $default 默认的参数
|
|
* @return mixed
|
|
*/
|
|
public static function get(string $key, ?string $default = null)
|
|
{
|
|
$key = self::$prefix . $key;
|
|
$value = $_COOKIE[$key] ?? $default;
|
|
return is_array($value) ? $default : $value;
|
|
}
|
|
|
|
/**
|
|
* 设置指定的COOKIE值
|
|
*
|
|
* @param string $key 指定的参数
|
|
* @param mixed $value 设置的值
|
|
* @param integer $expire 过期时间,默认为0,表示随会话时间结束
|
|
*/
|
|
public static function set(string $key, $value, int $expire = 0)
|
|
{
|
|
$key = self::$prefix . $key;
|
|
$_COOKIE[$key] = $value;
|
|
Response::getInstance()->setCookie(
|
|
$key,
|
|
$value,
|
|
$expire,
|
|
self::$path,
|
|
self::$domain,
|
|
self::$secure,
|
|
self::$httponly
|
|
);
|
|
}
|
|
|
|
/**
|
|
* 删除指定的COOKIE值
|
|
*
|
|
* @param string $key 指定的参数
|
|
*/
|
|
public static function delete(string $key)
|
|
{
|
|
$key = self::$prefix . $key;
|
|
if (!isset($_COOKIE[$key])) {
|
|
return;
|
|
}
|
|
|
|
Response::getInstance()->setCookie($key, '', -1, self::$path, self::$domain, self::$secure, self::$httponly);
|
|
unset($_COOKIE[$key]);
|
|
}
|
|
}
|