在本文中,我们将详细介绍BEESCMS输出配置不能设置的解决方案的各个方面,同时,我们也将为您带来关于Android闹钟设置的解决方案、BEESCMS输出配置不能设置的解决办法、centos6.5配置
在本文中,我们将详细介绍BEESCMS输出配置不能设置的解决方案的各个方面,同时,我们也将为您带来关于Android闹钟设置的解决方案、BEESCMS输出配置不能设置的解决办法、centos6.5配置静态IP时BCAST不能设置的解决方法、CMS系统:PHPCMS V9后台提示No permission resources的解决方案的有用知识。
本文目录一览:- BEESCMS输出配置不能设置的解决方案
- Android闹钟设置的解决方案
- BEESCMS输出配置不能设置的解决办法
- centos6.5配置静态IP时BCAST不能设置的解决方法
- CMS系统:PHPCMS V9后台提示No permission resources的解决方案
BEESCMS输出配置不能设置的解决方案
帮朋友弄个网站,用了BEESCMS的程序,因为是头一次用,各个功能还不是非常熟悉,不过还好,多试试就会了。但是有一个功能,始终不能生效,就是后台的输出配置有一个选项不能设置。如图:
beescms输出设置不能生效
找到文件/data/cn_tpl_info.php,原因找了很久,想想需要是编码的原因。换成utf-8编码,再将对应的字段一一重新写好,如图。
beescms输出设置不能生效
上传替换掉/data/cn_tpl_info.php,显示正常,设置生效。
beescms输出设置不能生效
如果嫌麻烦,你可以直接复制下边的代码,保存为cn_tpl_info.php文件。
Copy to ClipboardLiehuo.Net Codes引用的内容:[]
<?php
$tpl=array (
0 =>
array (
'type' => 'tag',
'name' => '首页联系方式',
'info' => '',
),
1 =>
array (
'type' => 'tag',
'name' => '首页企业简介',
'info' => '',
),
2 =>
array (
'type' => 'article',
'name' => '首页案例展示',
'info' => '',
),
3 =>
array (
'type' => 'article',
'name' => '首页文章中心图片显示',
'info' => '数量从0到1,显示上传有缩略图的内容',
),
4 =>
array (
'type' => 'article',
'name' => '首页文章中心',
'info' => '',
),
5 =>
array (
'type' => 'article',
'name' => '首页产品展示',
'info' => '上传缩略图才会在该位置显示',
),
6 =>
array (
'type' => 'market',
'name' => '漂浮客服1',
'info' => '',
),
7 =>
array (
'type' => 'market',
'name' => '漂浮客服2',
'info' => '',
),
8 =>
array (
'type' => 'market',
'name' => '漂浮客服3',
'info' => '',
),
9 =>
array (
'type' => 'tag',
'name' => '首页企业简介',
'info' => '',
),
10 =>
array (
'type' => 'market',
'name' => '漂浮客服组01',
'info' => '',
),
11 =>
array (
'type' => 'market',
'name' => '漂浮客服组02',
'info' => '',
),
12 =>
array (
'type' => 'market',
'name' => '漂浮客服组03',
'info' => '',
),
13 =>
array (
'type' => 'tag',
'name' => '产品内容详细页联系方式',
'info' => '',
),
14 =>
array (
'type' => 'list_nav',
'name' => '产品内容详细页产品导航',
'info' => '',
),
15 =>
array (
'type' => 'article',
'name' => '产品内容详细页热点内容',
'info' => '排序使用点击排序',
),
16 =>
array (
'type' => 'article',
'name' => '产品内容详细页推荐产品',
'info' => '',
),
17 =>
array (
'type' => 'market',
'name' => '产品内容详细页固定客服组',
'info' => '',
),
18 =>
array (
'type' => 'form',
'name' => '产品内容详细页表单',
'info' => '',
),
19 =>
array (
'type' => 'tag',
'name' => '新闻内容详细页联系方式',
'info' => '',
),
20 =>
array (
'type' => 'list_nav',
'name' => '新闻内容详细页产品导航',
'info' => '',
),
21 =>
array (
'type' => 'article',
'name' => '新闻内容详细页热点内容',
'info' => '排序使用点击排序',
),
22 =>
array (
'type' => 'article',
'name' => '章内容详细页推荐产品',
'info' => '发布产品时勾选”日志o“勾选推荐才能显示',
),
23 =>
array (
'type' => 'tag',
'name' => '产品栏目页联系方式',
'info' => '',
),
24 =>
array (
'type' => 'list_nav',
'name' => '产品栏目页产品导航',
'info' => '',
),
25 =>
array (
'type' => 'article',
'name' => '产品栏目页热点内容',
'info' => '排序使用点击排序',
),
26 =>
array (
'type' => 'article',
'name' => '产品栏目页推荐产品',
'info' => '发布产品时勾选”日志o“勾选推荐才能显示',
),
);
?>
Android闹钟设置的解决方案
Android设置闹钟并不像IOS那样这么简单,做过Android设置闹钟的开发者都知道里面的坑有多深。下面记录一下,我解决Android闹钟设置的解决方案。
主要问题
1、API19开始AlarmManager的机制修改。
2、应用程序被Kill掉后,设置的闹钟不响。
3、6.0以上进入Doze模式会使JobScheduler停止工作。
4、手机设置重启后,闹钟失效问题。
API19以上AlarmManager机制的修改
API19之前AlarmManager提供了三个设置闹钟的方法,由于业务需求闹钟只需要一次性,所以采用set(int type,long startTime,PendingIntent pi);这个方法。
从API 19开始,AlarmManager的机制都是非准确传递,操作系统将会转换闹钟,来最小化唤醒和电池使用。
由于之前的程序,没有对API19以上的闹钟设置做处理,导致在4.4以上的手机设置闹钟无响应(应用程序没有被杀死的情况也没有闹钟)。
因些,设置闹钟需要根据API的版本进行分别处理设置。代码如下:
AlarmManager am = (AlarmManager) getActivity() .getSystemService(Context.ALARM_SERVICE); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { am.setExact(AlarmManager.RTC_WAKEUP,TimeUtils .stringToLong(recordTime,TimeUtils.NO_SECOND_FORMAT),sender); }else { am.set(AlarmManager.RTC_WAKEUP,sender); }
这样,保证闹钟在应用程序没有被Kill掉的情况闹钟。
应用程序被Kill掉时的处理
应用程序被Kill掉后,设置的闹钟失效,这里利用守护进程以及灰色保活来保证后台闹钟服务不被Kill掉。当应用程序以及闹钟服务被Kill掉,守护进程以及灰色保活来重新启动闹钟服务,并且重新设置闹钟。
关于守护进程的处理,这里采用开源的守护进程库。Android-AppDaemon
在闹钟服务的onCreat加入Android-AppDaemon这个开源的守护进程。代码如下:
@Override public void onCreate() { super.onCreate(); Daemon.run(DaemonService.this,DaemonService.class,Daemon.INTERVAL_ONE_MINUTE); startTiMetask(); grayguard(); }
为进一步保证闹钟服务的存活,同加上灰色保活(利用系统的漏洞启动前台Service)。
代码如下:
private void grayguard() { if (Build.VERSION.SDK_INT < 18) { //API < 18 ,此方法能有效隐藏Notification上的图标 startForeground(GRAY_SERVICE_ID,new Notification()); } else { Intent innerIntent = new Intent(this,DaemonInnerService.class); startService(innerIntent); startForeground(GRAY_SERVICE_ID,new Notification()); } //发送唤醒广播来促使挂掉的UI进程重新启动起来 AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE); Intent alarmIntent = new Intent(); alarmIntent.setAction(WakeReceiver.GRAY_WAKE_ACTION); PendingIntent operation = PendingIntent.getbroadcast(this,WAKE_REQUEST_CODE,alarmIntent,PendingIntent.FLAG_UPDATE_CURRENT); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { alarmManager.setwindow(AlarmManager.RTC_WAKEUP,System.currentTimeMillis(),ALARM_INTERVAL,operation); }else { alarmManager.setInexactRepeating(AlarmManager.RTC_WAKEUP,operation); } } /** * 给 API >= 18 的平台上用的灰色保活手段 */ public static class DaemonInnerService extends Service { @Override public void onCreate() { Log.i(LOG_TAG,"InnerService -> onCreate"); super.onCreate(); } @Override public int onStartCommand(Intent intent,int flags,int startId) { Log.i(LOG_TAG,"InnerService -> onStartCommand"); startForeground(GRAY_SERVICE_ID,new Notification()); //stopForeground(true); stopSelf(); return super.onStartCommand(intent,flags,startId); } @Override public IBinder onBind(Intent intent) { throw new UnsupportedOperationException("Not yet implemented"); } @Override public void onDestroy() { Log.i(LOG_TAG,"InnerService -> onDestroy"); super.onDestroy(); } }
上面操作尽可能提高闹钟服务的存活。但是在5.0以上的手机,利用系统的自带的Clean功能的时候,还是会将闹钟服务彻底的干掉。为了解决5.0以上的问题,这里引入5.0以上的新特性 JobScheduler。
5.0以上的JobScheduler
在这里利用5.0以上的JobScheduler创建一个定时的任务,定时检测闹钟服务是否存在,没在存在则重新启动闹钟服务。(这里我设置每一分钟检测一次闹钟服务)
在进入应用程序的时候检测当前系统是否是5.0以上,如果是则启动JobScheduler这个服务。代码如下:
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { mJobScheduler = (JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE); JobInfo.Builder builder = new JobInfo.Builder(JOB_ID,new ComponentName(getPackageName(),JobSchedulerService.class.getName())); builder.setPeriodic(60 * 1000); //每隔60秒运行一次 builder.setRequiresCharging(true); builder.setPersisted(true); //设置设备重启后,是否重新执行任务 builder.setRequiresdeviceidle(true); if (mJobScheduler.schedule(builder.build()) <= 0) { //If something goes wrong } }
其中的builder.setPersisted(true); 方法是设备重启后,是否重新执行任务,在这测过是可以重新启动任务的。
上面的操作进一步保证了闹钟服务被Kill掉后,重新启动服务。但是在6.0以上引入了Doze模式,当6.0以上的手机进入这个模式后,便会使JobScheduler停止工作。
6.0以上Doze模式的处理
为了让JobScheduler可以在6.0以上进入Doze模式工作,这里针对6.0以上的Doze模式做特殊的处理-忽略电池的优化。
在Manifest.xml中加入权限。
<uses-permission android:name="android.permission.REQUEST_IGnorE_BATTERY_OPTIMIZATIONS"/>
在设置闹钟的时候,判断系统是否是6.0以上,如果是,则判断是否忽略电池的优化。判断是否忽略电池优化代码如下:
@TargetApi(Build.VERSION_CODES.M) public static boolean isIgnoringBatteryOptimizations(Activity activity){ String packageName = activity.getPackageName(); PowerManager pm = (PowerManager) activity .getSystemService(Context.POWER_SERVICE); if (pm.isIgnoringBatteryOptimizations(packageName)) { return true; }else { return false; } }
如果没有忽略电池优化的时候,弹出提醒对话框,提示用户进行忽略电池优化操作。代码如下:
/** * 针对N以上的Doze模式 * * @param activity */ public static void isIgnoreBatteryOption(Activity activity) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { try { Intent intent = new Intent(); String packageName = activity.getPackageName(); PowerManager pm = (PowerManager) activity.getSystemService(Context.POWER_SERVICE); if (!pm.isIgnoringBatteryOptimizations(packageName)) { // intent.setAction(Settings.ACTION_IGnorE_BATTERY_OPTIMIZATION_SETTINGS); intent.setAction(Settings.ACTION_REQUEST_IGnorE_BATTERY_OPTIMIZATIONS); intent.setData(Uri.parse("package:" + packageName)); activity.startActivityForResult(intent,REQUEST_IGnorE_BATTERY_CODE); } } catch (Exception e) { e.printstacktrace(); } } }
在界面重写onActivityResult方法来捕获用户的选择。如,代码如下:
@Override protected void onActivityResult(int requestCode,int resultCode,Intent data) { if (resultCode == RESULT_OK) { if (requestCode == BatteryUtils.REQUEST_IGnorE_BATTERY_CODE){ //Todo something } }else if (resultCode == RESULT_CANCELED){ if (requestCode == BatteryUtils.REQUEST_IGnorE_BATTERY_CODE){ ToastUtils.show(getActivity(),"请开启忽略电池优化~"); } } }
补充
当应用程序被Kill掉,但是闹钟的服务没有被Kill掉的,这时候又设置了闹钟。这就意味着设置的闹钟没有放到闹钟服务那里。所以这种情况,设置的闹钟会失效。为了解决这种情况,利用AIDL(闹钟服务在另一个进程的需要进程间通信)调用闹钟服务的重新设置闹钟方法重设闹钟。
在应用程序的onCreat()方法启动闹钟服务,然后再绑定闹钟服务。
private void initAlarmService() { startService(new Intent(this,DaemonService.class));//启动闹钟服务 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { //JobScheduler ... } //绑定闹钟服务 Intent intent = new Intent(this,DaemonService.class); intent.setAction("android.intent.action.DaemonService"); bindService(intent,mConnection,Context.BIND_AUTO_CREATE); }
在onDestroy()方法,调用闹钟服务的重设闹钟方法。代码如下:
@Override protected void onDestroy() { super.onDestroy(); try {//判断是否有闹钟,没有则关闭闹钟服务 String alarm = localPreferencesHelper.getString(LocalPreferencesHelper.ALARM_CLOCK); if (daemonService != -1 && mIRemoteService != null) { // android.os.Process.killProcess(daemonService); mIRemoteService.resetAlarm(); } if (!alarm.equals("[]")) { if (daemonService != -1) { startService(new Intent(this,DaemonService.class)); } } else { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { mJobScheduler.cancel(JOB_ID); } } unbindService(mConnection); //解除绑定服务。 } catch (Exception e) { } }
这里说明一下,当服务启动并且被绑定的情况下,unbindService是不会停止服务的。
最后
以上并不代表所有的Android手机的闹钟都可以用,这只是尽最大的可能保证大部分的手机。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
BEESCMS输出配置不能设置的解决办法
帮朋友弄个网站,用了BEESCMS的程序,因为是头一次用,各个功能还不是特别熟悉,不过还好,多试试就会了。但是有一个功能,始终不能生效,就是后台的输出配置有一个选项不能设置。如图:
beescms输出设置不能生效
找到文件/data/cn_tpl_info.PHP,原因找了很久,想想应该是编码的原因。换成utf-8编码,再将对应的字段一一重新写好,如图。
beescms输出设置不能生效
上传替换掉/data/cn_tpl_info.PHP,显示正常,设置生效。
beescms输出设置不能生效
如果嫌麻烦,你可以直接复制下边的代码,保存为cn_tpl_info.PHP文件。
copy to Clipboard Codes引用的内容:[www.jb51.cc] PHP $tpl=array ( 0 => array ( 'type' => 'tag','name' => '首页联系方式','info' => '',),1 => array ( 'type' => 'tag','name' => '首页公司简介',2 => array ( 'type' => 'article','name' => '首页案例展示',3 => array ( 'type' => 'article','name' => '首页新闻中心图片显示','info' => '数量从0到1,显示上传有缩略图的内容',4 => array ( 'type' => 'article','name' => '首页新闻中心',5 => array ( 'type' => 'article','name' => '首页产品展示','info' => '上传缩略图才会在该位置显示',6 => array ( 'type' => 'market','name' => '漂浮客服1',7 => array ( 'type' => 'market','name' => '漂浮客服2',8 => array ( 'type' => 'market','name' => '漂浮客服3',9 => array ( 'type' => 'tag',10 => array ( 'type' => 'market','name' => '漂浮客服组01',11 => array ( 'type' => 'market','name' => '漂浮客服组02',12 => array ( 'type' => 'market','name' => '漂浮客服组03',13 => array ( 'type' => 'tag','name' => '产品内容页联系方式',14 => array ( 'type' => 'list_nav','name' => '产品内容页产品导航',15 => array ( 'type' => 'article','name' => '产品内容页热点内容','info' => '排序使用点击排序',16 => array ( 'type' => 'article','name' => '产品内容页推荐产品',17 => array ( 'type' => 'market','name' => '产品内容页固定客服组',18 => array ( 'type' => 'form','name' => '产品内容页表单',19 => array ( 'type' => 'tag','name' => '文章内容页联系方式',20 => array ( 'type' => 'list_nav','name' => '文章内容页产品导航',21 => array ( 'type' => 'article','name' => '文章内容页热点内容',22 => array ( 'type' => 'article','name' => '章内容页推荐产品','info' => '发布产品时勾选”标志“勾选推荐才能显示',23 => array ( 'type' => 'tag','name' => '产品列表页联系方式',24 => array ( 'type' => 'list_nav','name' => '产品列表页产品导航',25 => array ( 'type' => 'article','name' => '产品列表页热点内容',26 => array ( 'type' => 'article','name' => '产品列表页推荐产品',); ?> |
centos6.5配置静态IP时BCAST不能设置的解决方法
由于我老爸不懂我电脑是否开关机,一台待机状态的电脑,直接给老爸拔掉电源,已经配置好的Linux系统直接崩溃,加上自己防范意识较浅,并未有对虚拟机进行快照或者克隆。之前配置的一切全都得重头开始,然后,今天在配置动态IP时,能够连接上网络,但是, 改成配置静态IP 时,出现了问题,本机可以PING到虚拟机,但是虚拟机无法PING 到外网,检查了所有的配置,发现,BCAST 并没有设置好。
注意看第一张图的几台IP基本配置:
IP配置完后,紧跟着就是配置Bcast,一定是这样,本人发现,变换位置会使得配置失败,这应该是个BUG!
CMS系统:PHPCMS V9后台提示No permission resources的解决方案
《CMS系统:PHPCMS V9后台提示No permission resources的解决方案》要点:
本文介绍了CMS系统:PHPCMS V9后台提示No permission resources的解决方案,希望对您有用。如果有疑问,可以联系我们。
这是因为Nginx的server name 配置的问题造成的.PHPcms v9的$_SERVER["SERVER_NAME"]这个服务器函数在Nginx下面获取不到的域名的.
找到文件:PHPcms/modules/admin/classes/admin.class.PHP
public function __construct() {
self::check_admin();
self::check_priv();
pc_base::load_app_func('global','admin');
if (!module_exists(ROUTE_M)) showmessage(L('module_not_exists'));
self::manage_log();
self::check_ip();
self::lock_screen();
self::check_hash();
if(pc_base::load_config('system','admin_url') && $_SERVER["SERVER_NAME"]!= pc_base::load_config('system','admin_url')) {
Header("http/1.1 403 Forbidden");
exit('No permission resources.');
}
}
以上代码中用到了$_SERVER["SERVER_NAME"]这个服务器函数 但是在Nginx下面有些却是获取不到的域名的.
将上面代码改为:
public function __construct() {
self::check_admin();
self::check_priv();
pc_base::load_app_func('global','admin');
if (!module_exists(ROUTE_M)) showmessage(L('module_not_exists'));
self::manage_log();
self::check_ip();
self::lock_screen();
self::check_hash();
if(pc_base::load_config('system','admin_url') && $_SERVER['HTTP_HOST']!= pc_base::load_config('system','admin_url')) {
Header("http/1.1 403 Forbidden");
exit('No permission resources.');
}
}
经测试,以上代码可完美解决PHPCMS V9后台提示No permission resources错误
原文地址:http://www.abcde.cn/info/show-23-976-1.html
关于BEESCMS输出配置不能设置的解决方案的问题我们已经讲解完毕,感谢您的阅读,如果还想了解更多关于Android闹钟设置的解决方案、BEESCMS输出配置不能设置的解决办法、centos6.5配置静态IP时BCAST不能设置的解决方法、CMS系统:PHPCMS V9后台提示No permission resources的解决方案等相关内容,可以在本站寻找。
本文标签: