TinySlideshow幻灯片相册代码
在制作图片幻灯片相册效果时,发现了这个开源的TinySlideshow代码,采用DIV+CSS+JS控制的代码,可以很好的适应各种情况,通过修改CSS文件,可以控制相册的大小等展示风格,通过修改html页面来控制数据的读取,很好的结合任何一款内容发布系统,各数据信息都是分离的。可以加以推广应用到WEB开发中。
在制作图片幻灯片相册效果时,发现了这个开源的TinySlideshow代码,采用DIV+CSS+JS控制的代码,可以很好的适应各种情况,通过修改CSS文件,可以控制相册的大小等展示风格,通过修改html页面来控制数据的读取,很好的结合任何一款内容发布系统,各数据信息都是分离的。可以加以推广应用到WEB开发中。
一、自定义错误信息页面,并根据所请求的URL所在的域,跳转到所在域名。
二、自定义APACHE错误信息,指定错误信息页面。配置文件里面有例子信息,去掉下面的注释符号#,激活。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | Alias /error/ "/usr/local/apache2/error/" <Directory "/usr/local/apache2/error"> AllowOverride None Options IncludesNoExec AddOutputFilter Includes html AddHandler type-map var Order allow,deny Allow from all LanguagePriority en cs de es fr it ja ko nl pl pt-br ro sv tr ForceLanguagePriority Prefer Fallback </Directory> ErrorDocument 400 /error/HTTP_BAD_REQUEST.html.var ErrorDocument 401 /error/HTTP_UNAUTHORIZED.html.var ErrorDocument 403 /error/HTTP_FORBIDDEN.html.var ErrorDocument 404 /error/404/index.html ErrorDocument 405 /error/HTTP_METHOD_NOT_ALLOWED.html.var ErrorDocument 408 /error/HTTP_REQUEST_TIME_OUT.html.var ErrorDocument 410 /error/HTTP_GONE.html.var ErrorDocument 411 /error/HTTP_LENGTH_REQUIRED.html.var ErrorDocument 412 /error/HTTP_PRECONDITION_FAILED.html.var ErrorDocument 413 /error/HTTP_REQUEST_ENTITY_TOO_LARGE.html.var ErrorDocument 414 /error/HTTP_REQUEST_URI_TOO_LARGE.html.var ErrorDocument 415 /error/HTTP_UNSUPPORTED_MEDIA_TYPE.html.var ErrorDocument 500 /error/HTTP_INTERNAL_SERVER_ERROR.html.var ErrorDocument 501 /error/HTTP_NOT_IMPLEMENTED.html.var ErrorDocument 502 /error/HTTP_BAD_GATEWAY.html.var ErrorDocument 503 /error/HTTP_SERVICE_UNAVAILABLE.html.var ErrorDocument 506 /error/HTTP_VARIANT_ALSO_VARIES.html.var |
三、实现跳转JS。
新建错误信息html页面,页面中关键代码如下:
1 | 页面没有找到,将在<SPAN id=return_page>5</SPAN>秒钟后带您返回网站首页 ! |
倒计时5秒后,跳转页面。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | var ym=document.domain;//获取请求的URL域名+++ 关键 ++++ var returnid=5; function return_prepage(){ document.getElementById("return_page").innerHTML=returnid+""; if(returnid==0){ window.location.href="http://"+ym; //重定向到请求的域名网站 } returnid=returnid-1; if(returnid>-1){ window.setTimeout("return_prepage()",1000);} } return_prepage(); |
首先查看apache是否加载了mod_deflate.so模块,如果没有需要安装加载。
找到并下载和当前apache版本相同的源码文件,解压缩到/home目录下,
在apache安装目录下执行:
/usr/local/apache2/bin/apxs -i -c /home/httpd-2.0.63/modules/filters/mod_deflate.c
会自动在 httpd.conf添加
LoadModule deflate_module modules/mod_deflate.so添加如下设置:
<IfModule mod_deflate.c> <Location /> #Insert filter SetOutputFilter DEFLATE # Netscape 4.x has some problems… BrowserMatch ^Mozilla/4 gzip-only-text/html # Netscape 4.06-4.08 have some more problems BrowserMatch ^Mozilla/4\.0[678] no-gzip # MSIE masquerades as Netscape, but it is fine # BrowserMatch \bMSIE !no-gzip !gzip-only-text/html # NOTE: Due to a bug in mod_setenvif up to Apache 2.0.59 # the above regex won’t work. You can use the following # workaround to get the desired effect: # BrowserMatch \bMSIE !no-gzip !gzip-only-text/html force-gzip BrowserMatch \bMSIE !no-gzip !gzip-only-text/html # Don’t compress images and other SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary SetEnvIfNoCase Request_URI .(?:exe|t?gz|zip|bz2|sit|rar)$ no-gzip dont-vary SetEnvIfNoCase Request_URI .(?:pdf|doc)$ no-gzip dont-vary AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css AddOutputFilterByType DEFLATE application/x-javascript # Make sure proxies don’t deliver the wrong content Header append Vary User-Agent env=!dont-vary #DeflateFilterNote ratio ratio_info #LogFormat '"%v %h %l %u %t “%r" %>s %b "%{Referer}i" "%{User-Agent}i"" (%{ratio}n)' deflate #CustomLog logs/deflate_log deflate </Location> </IfModule>
停止apache服务./apachectl stop,报错如下:
Cannot load /usr/local/apache2/modules/mod_deflate.so into server: /usr/local/apache2/modules/mod_deflate.so: undefined symbol: deflate解决如下:
vi /usr/local/apache2/bin/apr-config 修改LDFLAGS=" " 为 LDFLAGS="-lz"
停止启动服务:仍提示:
DeflateFilterNote not allowed here
CustomLog not allowed here
注释掉后,正常。
对 web服务器进行安全性端口扫描,发现一些问题,apache加以调整:
1、HTTP TRACE method
需要关闭HTTP TRACE 方法,检测apache是否打开了trace方法,使用如下方法:
telnet 127.0.0.1 80 Trying 127.0.0.1…
Connected to 127.0.0.1.
Escape character is ‘^]’.
TRACE / HTTP/1.0
Host: foo然后按两次回车,出现下面的信息,证明方法激活了。
HTTP/1.1 200 OK
Date: Sat, 20 Oct 2007 20:39:36 GMT
Server: Apache/2.2.6 (Debian)
Connection: close
Content-Type: message/http
TRACE / HTTP/1.0
Host: foo
否则会出现:
HTTP/1.1 403 Forbidden
等信息。
解决方法:修改httpd.conf,修改如下数值:TraceEnable Off
2、隐藏apache版本等信息:
访问一个不存在的页面,apache会报如下错误:
Not Found
The requested URL /ss.c was not found on this server.
———————–
Apache/2.0.63 (Unix) DAV/2 mod_jk/1.2.20 Server at ip Port 80
错误信息中包含apache的版本和使用的操作系统等.
解决办法:修改httpd.conf:
设置如下数值:
ServerTokens Prod(默认为Full)
ServerSignature Off(默认为On)
数据导入,首先需要知道导入端oracle的dpump_dir目录,通过执行下面的语句查看系统表:
SELECT * FROM dba_directories

得到DPUMP_DIR路径为:/var/web/exp_bak/pumpdata
将备份的dmp文件放到这个路径下,执行:
./impdp user/pass dumpfile=Oracle_bak_20091130.dmp directory=dpump_dir
dmp文件必须要放到dpump_dir目录下,并且dumpfile 不能带路径,否则,出现下面类似错误:
UDI-00008: operation generated ORACLE error 1034 ORA-01034: ORACLE not available ORA-27101: shared memory realm does not exist Linux-x86_64 Error: 2: No such file or directory UDI-00003: all allowable logon attempts failed
用oracle帐户登陆系统后,执行cat ~/.bash_profile,查看oracle帐户的环境变量。
如果用su oracle,则oracle环境变量不会执行,可以运行source ~/.bash_profile
执行环境变量配置文件而不必重新用oracle帐户登陆。
一、前言
系统备份会定期产生备份文件,日积月累,早期的备份应该删除。设定每周清理一下备份文件,只保留最近7天的数据。可以根据文件的时间检索并删除。适用于系统管理中的数据备份文件和日志文件的管理。
二、SHELL脚本
find /var/web/apache/logs -type f -ctime +7 -exec rm {} \;这个脚本会将指定目录及其子目录的所有符合条件的文件删除,没有提示。
三、加入计划任务
将上述命令写入一shell脚本back.sh
赋予可执行权限chmod 755 back.sh
编辑计划任务:
#crontab -u user -e
0 2 * * 0 /home/back.sh
back.sh脚本会在每周日凌晨2点执行。
有关crontab的详细命令参见相关资料,有很多。
这里只简要说明下,计划任务前5位用数字表示依次是:
分:(0——59)
小时:(1——23)
日:(1——31)
月:(1——12)
星期:(0——6,0为星期日)
一、前言
CMS中模板用置标嵌套头尾模板的方法,方便快捷,但是存在弊端,当文档数据量庞大时,只要嵌套的头尾模板稍有改动,就得完全发布站点才能更新所有的文档模板。数据量有几十万条,这个就是噩梦。使用SSI技术,将头尾作为独立文件嵌入到页面中,只要更新发布头尾文件就可以了。
二、Apache配置
Apache默认是不支持SSI的,更改httpd.conf来进行配置。
搜索“AddType text/html .shtml”,找到下面两行:
# AddType text/html .shtml # AddOutputFilter INCLUDES .shtml
将这两行前面的#注释去掉。
搜索下面的默认页配置:
DirectoryIndex index.html index.htm将index.shtml放到第一个位置
DirectoryIndex index.shtml index.html index.htm接下来修改虚拟主机配置来支持shtml
例如下面的虚拟主机配置:
<VirtualHost *:80> ServerAdmin webmaster@cas.cn <Directory "/var/web/casweb/cas"> Options -Indexes FollowSymLinks Includes Order allow,deny Allow from all </Directory> DocumentRoot /var/web/casweb/cas/ ServerName www.cas.cn ErrorLog logs/www.cas.cn-error_log TransferLog "|/usr/local/sbin/cronolog /usr/local/apache2/logs/www.cas.cn-%Y%m%d-access_log" </VirtualHost>
蓝色的Includes是在原来的基础上增加的。
三、SSI页面调用方法
用法:
<!--#include virtual="index.shtml" -->
include路径不能跨域,只能使用相对路径。
将上述代码插入到模板代码中,并将模板扩展名改为shtml
链接的文件名可以使用置标来获取,但必须指定具体的文件名,如index.shtml
wordpress的一些主题,对常用插件的支持不尽相同,当不支持你所希望的插件时,就需要手动添加对该插件的支持。以PageNavi插件为例,作为必装的插件,更好的实现文章列表的分页导航,取代系统默认的Previous Entries、Next Entries 。
安装并激活Wp-PageNavi插件。打开主题的index文件,找到例如下面的一段:系统默认的翻页代码:
<div class="alignleft">
<?php next_posts_link('← Previous Entries') ?>
</div>
<div class="alignright">
<?php previous_posts_link('Next Entries →') ?>
</div>只需要在这代码的外围加上对PageNavi插件的判断、应用:
<?php if(function_exists('wp_pagenavi')){ wp_pagenavi(); } else { ?> <div class="alignleft"> <?php next_posts_link('← Previous Entries') ?> </div> <div class="alignright"> <?php previous_posts_link('Next Entries →') ?> </div> <?php } ?>
判断wp_pagenavi插件是否激活存在,是就应用 wp_pagenavi();否则,还用系统默认方式。
对其它插件的支持,基本上也是按照这种方式应用的。
某个系统管理员一不小心直接用数据库管理工具把一文章表的标题字段类型改了,导致所有文章标题不能正常显示了。上万条的数据有点懵了。之前数据库也没有备份过。试图修复数据库也没有成功。唯一的希望寄托在数据库本身的结构上。
由于文章的部分信息在另外一个表中也有所体现,标题信息正在其中。只要将这部分信息重写回表中就可以恢复。两个表是通过ID相关联的。检索出文章对应的标题并写回原表。但是原表文章范围大于另一个表,只要少量信息不存在。能恢复大部分信息就好了。
<?php $DB_Server = "localhost"; $DB_Username = "root"; $DB_Password = "password"; $DB_DBName = "dbname"; //$DB_TBLName = "column_article"; $Connect = @mysql_connect($DB_Server, $DB_Username, $DB_Password) or die("Couldn't connect."); $Db = @mysql_select_db($DB_DBName, $Connect) or die("Couldn't select database."); $sql = "Select column_article.title,column_article.articleid,article.title,article.id from column_article,article where column_article.articleid=article.id"; $ALT_Db = @mysql_select_db($DB_DBName, $Connect) or die("Couldn't select database"); $result = @mysql_query($sql,$Connect) or die(mysql_error()); $i = 0; while($row = mysql_fetch_row($result)) { $title2=$row[0]; $title2id=$row[1]; $upd = @mysql_query("update article set article.title='$title2' where article.id=$title2id",$Connect); $i++; } return (true); ?>
linux下用户创建文件、文件夹都会有一个默认权限,系统默认文件夹权限是755,文件权限是644这个默认权限是可以设定的,就是通过umask,通过在shell下运行umask命令来看看当前的umask数值是多少,例如文件夹默认权限是755,他的umask数值为022。
这个数值表示的是什么意思,又如何来计算出想要的umask值。umask是在下面的配置文件中设定/etc/profile(全局设置),$ [HOME]/.bash_profile或者$ [HOME]/.profile(当前用户的设置,操作系统版本不同,文件名会不同)。在配置文件中加入一行umask 022即可。
umask值的计算方法,是通过权限的补码得来。例如文件夹权限755,文件夹的umask各位数值最大可以到7,各位数的补码就是022;而文件权限最大只能到6,因为系统不允许新建文件拥有执行权限。
umask值与文件、目录权限对照表:
umask 文件 目录
——————————
0 6 7
1 6 6
2 4 5
3 4 4
4 2 3
5 2 2
6 0 1
7 0 0
最新评论