发新话题
打印

pommo mailinglist

pommo mailinglist

http://pommo.org/
似乎好久都没有新的开发了
乐乎设计,乐乎生活~

TOP

poMMo Themes Overview Themes control the look and feel of the program
Themes consist of smarty template files
Smarty is a popular templating engine for PHP. It seperates "business" logic (for PHP programmers) from design logic (for web designers), making it possible for most people to change the look and feel of the program without being overwhelmed by PHP code.Themes can be found under the /themes directory, and adhere to these organizational guidelines:
  • Layout: Themes consist of a collection of template (.tpl) files under Theme Directory. All administrative pages (subscriber management, mailing creation, list setup, etc.) reference template files in the admin subdirectory of a Theme Directory. All user pages (user login, unsubscription/update records page, confirmation page, etc.) reference template files in the theme's user subdirectory. The subscription form templates are found in the subscribe subdirectory. See the Anatomy of a Theme for a model.
  • Organization: The program references template files of the same name as their .php counterpart. For instance, /admin/setup/demographics_edit.php will attempt to load /themes/default/admin/demographics_edit.tpl if using the "default" theme.
  • Behavior: If a page's template file cannot be found in the current theme's directory, it tries to find it in the "default" theme's directory. This allows you to create themes which effect only one or two pages, and rely on the default theme's templates for the rest.
  • Resources There is a "shared" directory in /themes which contains javascripts and application images that the default theme uses. The same images, javascripts, and stylesheets can be accessed by any theme's template file using "{$url.theme.shared}/file.to.include". A full list of variables available to the templates is in the Resource section below.
乐乎设计,乐乎生活~

TOP

MySQL伴随着我已有四五年了,在使用MySQL的过程中,也碰到过字符编码问题(乱码)。
在Google中搜索“mysql 乱码”,可以查到“429,000”条结果;搜索“jsp 乱码”,可以查到“335,000”条结果,当然JSP乱码不一定就是MySQL乱码,但多数情况是编码问题(可能是页面编码、数据库编码)。
可见,编码问题在我们开发过程中是经常出现的,因此对编码的了解、设置和修改就显得及其重要了。
今天对MySQL边学习边查资料特意整理总结本文,以作备份,希望给各网友参考,一起学习讨论。
一、MySQL字符集和校对规则
我们都知道,字符集就是一套文字符号及其编码、比较规则的集合,因为计算机只认识二进制代码,所有我们必须要有一个转换。
MySQL的字符集包括字符集(Character Set)和校对规则(Collation)两个概念。字符集是用来定义MySQL存储字符串的方式,而校对规则则定义了比较字符串的方式。
字符集和校对规则是一对多的关系,每个字符集至少对应一个校对规则,称为默认校对规则。
查看所有字符集的命令:show character set;
或是查看information_schema.character_sets,可以得到所有的字符集和它的默认的校对规则,它的表结构:desc information_schema.character_sets;
查看字符集的校对规则:show collation like 'GBK%';
校对规则命名约定:以其相关的字符集名开始,通常包括一个语言名,并且以_ci(大小写不敏感)_cs(大小写敏感)_bin(二元,即比较是基于字符编码的值而与语言无关)结束。
实验命令:
select case when 'A' COLLATE utf8_general_ci = 'a' COLLATE utf8_general_ci then 'YES' else 'NO' end;(YES)
select case when 'A' COLLATE gbk_chinese_ci = 'a' COLLATE gbk_chinese_ci then 'YES' else 'NO' end;(YES)
select case when 'A' COLLATE gbk_bin = 'a' COLLATE gbk_bin then 'YES' else 'NO' end;(NO)
二、设置字符集
MySQL的字符集和校对规则有4个级别的默认设置:服务器级、数据库级、表级和字段级。
服务器级:
[mysqld]
default-character-set=utf8
[mysql]
default-character-set=utf8
或是启动时加上参数:mysqld --default-character-set=utf8
或是编译时加上参数:./configure --width-charset=utf8
查看字符集和校对规则:
show variables like 'character_set_server';
show variables like 'collation_server';

数据库级:
查看字符集和校对规则:
show variables like 'character_set_database';
show variables like 'collation_database';

表级:
查看字符集和校对规则:
show create table t \G
四、简单修改字符集
简单修改只对以后的数据有影响,如果数据库中没有数据或是不想修改以前的数据,可以使用简单修改。
简单修改命令:
alter database character set utf8;
alter table t character set utf8;

个人推荐在创建数据库时明确指定字符集和校对规则,避免受到默认值的影响。
创建数据库时指定:
create database databasename default charset GBK;
创建数据表时指定:
create table tablename(
....
) ENGIND=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
五、完全修改字符集
当数据库中已有数据,想修改数据集,不能通过简单的修改字符集完成,需要先将原数据导出,经过适当调整后重新导入才可完成。
通过七步完成字符集的完全修改(假设原字符集是latin1,想修改成GBK)。
1、导出表结构:
mysqldump -uroot -p --default-character-set=GBK -d databasename>createdb.sql
说明:
--default-character-set=GBK 表示设置以什么字符集连接;
-d 表示只导出表结构,不导出数据。
2、手工修改createdb.sql中表结构定义中的字符集(latin1)为新的字符集(GBK);
3、确保数据库中的数据不再更新,导出所有的数据:
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-character-set=latin1 databasename>data.sql
说明:
--quick 该选项用于转储大的表,它强制mysqldump从服务器一次一行地检索表中的行而不是检索所有行,并在输出前将它缓存到内存中;
--extended-insert 使用包括几个values的多行insert语法;
--no-create-info 不要create table语句;
--default-character-set=latin1 表示按照原有的字符集导出所有的数据。
4、打开data.sql,将set names latin1修改成set names GBK;
5、使用新的字符集创建数据库:
create database databasename default charset GBK;
6、创建表:
mysql -uroot -p databasename < createdb.sql
7、导入数据:
mysql -uroot -p databasename < data.sql
六、最后
建议服务器的字符集参数不要修改,而是是创建数据库进加上字符集,特别是在创建表时记得加上,这样做的目的是为了使修改的影响最小化。


[ 本帖最后由 happyfan 于 2010-6-29 14:48 编辑 ]
乐乎设计,乐乎生活~

TOP

今天用到FCKeditor 发现图片不能上传,在网上找到的最佳答案()

1.把FCKeditor 文件夹放到 apache根目录下.(我的是E:\WWW)
2.打开FCKeditor\editor\filemanager\upload\php\config.php.修改如下:

      $Config['Enabled'] = true ;
      $Config['UserFilesPath'] = '/FCKeditor/UserFiles/' ;
3.打开FCKeditor\editor\filemanager\browser\default\connectors\php\config.php
                            $Config['Enabled'] = true ;
                            $Config['UserFilesPath'] = '/FCKeditor/UserFiles/' ;
4.打开FCKeditor\fckconfig.js 找到并修改如下:
var _FileBrowserLanguage        = 'php' ;        // asp | aspx | cfm | lasso | perl |

var _QuickUploadLanguage        = 'php' ;        // asp | aspx | cfm | lasso | php

5.下面这一步最重要啦.就是要在/FCKeditor/建一个UserFiles文件夹.呵呵,这个和 linux下是不同的.当然同志们也可以根据修改了.

补充: 两个配置文件的$Config['Enabled']项都要该为 true
         $Config['Enabled'] = true ;
乐乎设计,乐乎生活~

TOP

Kevin,

  They are not included in PR15, maybe in PR16. My stance on file attachments is that it is 99/100 times more appropriate to LINK to a file vs. attach it. Think of the (bandwidth) efficiency in sending a 3MB attachment to 18,000 subscribers, of which 30% will download the attachment -- a typical scenario.

~ Brice

的确多了附件,容易浪费带宽。
乐乎设计,乐乎生活~

TOP

5步实现Phpmyadmin导出Phpwind/Discuz!论坛会员电子邮箱到Gmail通讯录
我今天尝试用了下从phpmyadmin的导出Ms Excel的CSV文档到Gmail通讯录的功能,这里大致谈下成功小经验。其实写这篇文章,也是因为中国网络实验室(Labs of China)某大人写的Phpwind会员电子邮件地址导出程序,按照该程序上说的,可以读取PHPwind论坛会员的 email地址,复制到记事本进行群发通知邮件,解决部分空间商不支持在线群发的问题。这个工具如何呢?

我昨天在中国站长站下载来测试用了下,感觉这个工具并不怎么样。手工拷贝邮箱地址是在是麻烦,还有表格的项目比较复杂,除了邮箱和用户名这两个主要项目外,QQ、MSN、Yahoo!、签名,甚至还有密码都导出来了,整个表格显得很烦乱。5000多的会员的数据,直接拷贝,电脑差点都没翻译死掉了。而且拷贝到记事本,文件格式不是CSV的,无法导入Gmail通讯录。物极必反,其实大家可以直接使用phpmyadmin的数据导出管理功能,通过 phpmyadmin,可以将mysql数据表导出为CSV 数据、MS Excel 的 CSV 格式、 Microsoft Excel 2000、Microsoft Word 2000、LaTeX 、Open Document Spreadsheet、 Open Document Text 、PDF、SQL、XML等10多种格式,还可以选择zip或gzip压缩。
具体导出步骤如下(笔者以和意博客所用的MySQL 4.1.22版本、Phpwind 6.0RC UTF-8版本为例,Discuz 6.0 论坛的会员电子邮箱导出方法可以如法炮制。)
1、浏览器打开你的数据库地址,并用正确的帐号登陆。格式:http://网站域名/phpmyadmin。
2、 浏览phpwind所用的数据表(表头前缀一般为_pw),然后查找pw_members结构下的email和 username(由于是导出邮箱数据,只需要选中邮箱和用户名这两个项目就可以了,若需要其他项目,可以自行添加)。
3、选中这两个项,导航条选项卡选择“导出”,格式为“MS Excel 的 CSV 格式”,Excel版本选择Excel 2003/Macintosh,转存2000行,从记录 # 0开始(超过3000个email的数据,需要分配导出,因为gmail的导入程序限制了导入的CSV文件的大小,首次从0~2000,第二次选择 2001~4000,分批导出。),“另存为文件”勾上,压缩选择“无”。点执行,弹出下载,保存pw_members.csv文件到本地即可。
4、导入到Gmail通讯录。登陆Gmail,转到通讯录,选择导入,上载刚才的pw_members.csv即可。(若文件较大,可以分批次 pw_members_1.csv,pw_members_2.csv这样分批导入),按照Google的说法,Gmail支持以 CSV 格式(逗号分隔值)导入通讯录。
5、到这步就OK了,还有问题么?在这里留言吧,和意博客和你共同切磋探讨。
乐乎设计,乐乎生活~

TOP

导出获取提取Discuz论坛的用户邮箱【dz论坛】
2010年06月23日 星期三 11:33 A.M.
新建一个email.php文件
代码:
------------------------------------------------
复制内容到剪贴板
代码:
<?php
require_once './include/common.inc.php';
require_once DISCUZ_ROOT.'./include/forum.func.php';
$sql="Select `email` FROM ".UC_DBTABLEPRE."members`";
$query=$db->query($sql);
while ($row=$db->fetch_array($query))
{
echo $row['email']."\n";
}
?>
-----------------------------------------------------------
将email.php文件上传到论坛根目录。
通过访问http://你论坛名/email.php即可。




代码:
复制内容到剪贴板
代码:
<?php
require_once './include/common.inc.php';
require_once DISCUZ_ROOT.'./include/forum.func.php';
$sql="SELECT `email` FROM ".UC_DBTABLEPRE."members`";
$query=$db->query($sql);
while ($row=$db->fetch_array($query))
{
$fwrite = $row['email']."\n";
$fopen = fopen("1.txt","w");
fwrite($fopen,$fwrite);
}
?>
导出为txt的
乐乎设计,乐乎生活~

TOP

发新话题