晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/stando/www/wp-content/plugins/powerpress/ |
Upload File : |
<?php
// powerpress-feed-auth.php
function powerpress_feed_auth($feed_slug)
{
// See if a filter exists to perform the authentication...
$authenticated = apply_filters('powerpress_feed_auth', false, 'channel', $feed_slug);
if( !$authenticated )
{
$FeedSettings = get_option('powerpress_feed_'.$feed_slug);
/*
* php-cgi under Apache does not pass HTTP Basic user/pass to PHP by default
* For this workaround to work, add this line to your .htaccess file:
* RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
*/
// Workaround for HTTP Authentication with PHP running as CGI
if ( !isset($_SERVER['PHP_AUTH_USER']) && isset($_SERVER['HTTP_AUTHORIZATION'])) {
$ha = base64_decode( substr($_SERVER['HTTP_AUTHORIZATION'],6) ); // Chop off 'basic ' from the beginning of the value
if( strstr($ha, ':') ) { // Colon found, lets split it for user:password
list($_SERVER['PHP_AUTH_USER'], $_SERVER['PHP_AUTH_PW']) = explode(':', $ha);
}
unset($ha);
}
if( !isset($_SERVER['PHP_AUTH_USER']) || !isset($_SERVER['PHP_AUTH_PW']) ) {
powerpress_feed_auth_basic( $FeedSettings['title'] );
exit;
}
$user = $_SERVER['PHP_AUTH_USER'];
$password = $_SERVER['PHP_AUTH_PW'];
if( strpos( $user, '@', 1 ) !== false ) {
$userObjID = get_user_by( 'email', $user); // Get the user by email
if( !is_wp_error($userObjID) )
$user = $userObjID->user_login; // Use the user's login (not email) to authenticate
}
$userObj = wp_authenticate($user, $password);
if( !is_wp_error($userObj) )
{
// Check capability...
if( $userObj->has_cap( $FeedSettings['premium'] ) )
return; // Nice, let us continue...
powerpress_feed_auth_basic( $FeedSettings['title'], __('Access Denied', 'powerpress') );
exit;
}
// If we made it this far, then there was a wp_authenticate error...
powerpress_feed_auth_basic( $FeedSettings['title'], $userObj );
exit;
}
}
function powerpress_feed_auth_basic($realm_name, $error = false )
{
if( !defined('POWERPRESS_FEED_AUTH_PRINT_WP_ERRORS') && is_wp_error($error) ) {
$error = __('Unauthorized', 'powerpress');
}
if( empty($error) ) {
$error = __('Unauthorized', 'powerpress');
}
$error_heading = (is_wp_error($error)? __('Unauthorized', 'powerpress') : $error);
$error_message = (is_wp_error($error)?$error->get_error_message(): htmlspecialchars($error) );
if( !$error )
$error = __('Unauthorized', 'powerpress');
header('HTTP/1.0 401 Unauthorized');
header('Content-Type: text/html');
header('WWW-Authenticate: Basic realm="'. str_replace('"', '', $realm_name).'"');
echo '<!DOCTYPE html>'; // HTML5!
echo "\n";
?>
<html>
<head>
<meta http-equiv="Content-Type" content="<?php bloginfo('html_type'); ?>; charset=<?php bloginfo('charset'); ?>" />
<meta name="robots" content="noindex" />
<title><?php echo htmlspecialchars($error_heading); ?></title>
</head>
<body>
<p><?php echo $error_message; ?></p>
</body>
</html>
<?php
exit;
}
// eof