首页 > 编程技术 > php

用PHP和MySQL构建一个数据库驱动的网站(7)

发布时间:2016-11-25 17:14

现在我们已经有了允许用户输入一个笑话并将其加入到我们的数据库中的程序代码。现在剩下的就是将其加入到我们已做好的笑话显示页面。因为绝大多数的用户只会想要看看笑话,所以我们不想对我们的页面做大的更改,除非用户表示想要添加一个新的笑话。因为这个原因,我们的应用程序应该是一个多功能的页面。下面是程序的代码:
<HTML>
...
<BODY>
<?php
    // If the user wants to add a joke
    if (isset($addjoke)):
?>
<FORM ACTION="<?php echo($PHP_SELF); ?>" METHOD=POST>
<P>Type your joke here:<BR>
<TEXTAREA NAME="joketext" ROWS=10 COLS=40 WRAP></TEXTAREA><BR>
<INPUT TYPE=SUBMIT NAME="submitjoke" VALUE="SUBMIT">
</FORM>
<?php
    else:
    // Connect to the database server
    $dbcnx = @mysql_connect("localhost",
        "root", "mypasswd");
    if (!$dbcnx) {
        echo( "<P>Unable to connect to the " .
       "database server at this time.</P>" );
        exit();
    }
    // Select the jokes database
    if (! @mysql_select_db("jokes") ) {
        echo( "<P>Unable to locate the joke " .
       "database at this time.</P>" );
        exit();
    }
    // If a joke has been submitted,
    // add it to the database.
    if ("SUBMIT" == $submitjoke) {
PHP的面向对象编程:开发大型PHP项目的方法(一)
作者:Luis Argerich 译者:limodou
  这篇文章介绍了在PHP中的面向对象编程(OOP,Object Oriented Programming)。我将向你演示如何通
过使用一些OOP的概念和PHP的技巧来减少编码和提高质量。祝你好运!
  面向对象编程的概念:
  不同的作者之间说法可能不一样,但是一个OOP语言必须有以下几方面:
抽象数据类型和信息封装
继承
多态
  在PHP中是通过类来完成封装的:
--------------------------------------------------------------------------------<?php
class Something {
// 在OOP类中,通常第一个字符为大写
var $x;
function setX($v) {
// 方法开始为小写单词,然后使用大写字母来分隔单词,例如getValueOfArea()
$this->x=$v;
}
function getX() {
return $this->x;
}
}
?>--------------------------------------------------------------------------------
  当然你可以按自已的喜好进行定义,但最好保持一种标准,这样会更有效。
  数据成员在类中使用"var"声明来定义,在给数据成员赋值之前,它们是没有类型的。一个数据成员可
以是一个整数,一个数组,一个相关数组(associative array)或者是一个对象。
  方法在类中被定义成函数形式,在方法中访问类成员变量时,你应该使用$this->name,否则对一个方
法来说,它只能是局部变量。
  使用new操作符来创建一个对象:
  $obj=new Something;
  然后你可以使用成员函数通过:
  $obj->setX(5);
  $see=$obj->getX();
  在这个例子中,setX成员函数将5赋值给对象的成员变量x(不是类的),然后getX返回它的值5。
  你可以象:$obj->x=6那样通过类引用方式来存取数据成员,这不是一个很好的OOP习惯。我强烈建议通
过方法来存取成员变量。如果你把成员变量看成是不可处理的,并且只通过对象句柄来使用方法,你将是一
个好的OOP程序员。不幸的是,PHP不支持声明私有成员变量,所以不良代码在PHP中也是允许的。
  继承在PHP中很容易实现,只要使用extend关键字。
--------------------------------------------------------------------------------
<?php
class Another extends Something {
var $y;
function setY($v) {
$this->y=$v;
}
function getY() {
return $this->y;
}
}
?>--------------------------------------------------------------------------------
转自PHPBuilder.com

现在网站挂了,抓图看看
主程序show.php,不想格式化代码,格完后连自己都看不懂
里面可以设置
//设置锁定的最高目录,要以斜杠结尾。可以这样:$Lock_path="/home/"; $Lock_path="c:/"; $Lock_path="d:/mysql/";
$Lock_path="/";
//设置保护的后缀名,需要时去掉前面的双斜杠
//$shield_file=array("gif","php","zip");
//设置保护的文件名,需要时去掉前面的双斜杠
//$shield_folder=array("图片","程序","xltxlm","电影");
//设置相应网站,不要以斜杠结尾
$web_site="http://XXX.XXX.com/XXXX";
//设置网站对应的路径,要以斜杠结尾
$web_root="/home/htdocs/XXXXX/";

如需转载,请注明出处,谢谢!
以8.1.7.4.0为例说明:
8:版本号
1:新特性版本号
7:维护版本号
4:普通的补丁设置号码
0:特殊的平台补丁设置号码
另外有关Oracle是32bit/64bit的问题,说明如下:
在windows/linux系统中由于操作系统是32bit的,所以oracle肯定是32bit的;
在tru64中oracle肯定是64bit的;
在hpux/aix/solaris中要看具体情况了,如果是64bit的在server上启动sqlplus时会显示64bit的字样,你也可以通过
select * from v$version;或$ file $ORACLE_HOME/bin/oracle|more来查看,如:
<hpux>$ file $ORACLE_HOME/bin/oracle|more
/data1/app/oracle/product/8.1.7/bin/oracle: ELF-64 executable object file -
PA-RISC 2.0 (LP64)
如果希望支持大于1.75GB的SGA,那么建议使用64Bit oracle。32bit Oracle都有SGA的大小限制,虽然很多平台都有绕过去的办法,允许你开的大一些,终究不如直接用64Bit方便,而且即使绕过去,也还是不能开的很大。
 别的差别不大。

ldap+qmail+postaci    安装, 用户管理
参考文献:
1. 建一个大容量的webmail系统(作者:谢顺华)
    目前唯一能找到的中文qmail+ldap资料
    http://www.linuxforum.net/doc/webmail.html
2. Postaci Webmail
    基于php的webmail系统, 支持pop3, imap, 使用数据库做缓存.
    相对于imp和sqwebmail来说, 配置相当容易, 而且界面很好.
    (http://www.trlinux.com/)
3. Simple ldap user admin tool
    For Qmail的php版用户管理, 可以设置用户资料, 别名, maillist, 公司组织...
    http://sourceforge.net/projects/alldap/
4. Softerra LDAP Browser
    win32的ldap查看修改工具
    http://www.ldapbrowser.com
5. Life With qmail-ldap
    http://www.lifewithqmail.org/ldap/
6. Life With qmail
    http://www.lifewithqmail.org/
说明:
    考虑到qmail使用系统用户在管理上不大方便. 而使用mysql作为用户又会和mysql用户冲突, 而且mysql的局限性很大, 没有ldap的open和自由扩展特性. 使用ldap后, 利用php的ldap函数就可以实现用户管理, 用户可方便的自行编程解决用户管理.
    因为不是虚拟主机, 所以选用了配置简单, 好用的Postaci和Simple ldap user admin tool. 适合单一团体/公司使用.
安装:
1. openldap请参考文献1的步骤1.在/etc/openldap目录下是openldap的设置, 除了要按参考1中增加qmail的qmailUser类型外, 还要注意修改slapd.conf文件, 关键内容如下:
#你的公司名, 最好用站点名
suffix       "dc=test, dc=com"
#管理员名称, 类似于系统管理员. 很长, 但是很重要.
rootdn       "cn=Manager, dc=test, dc=com"
#管理员密码(这里用的是明文密码)
rootpw       secret
加入基本数据:
ldapadd -D "cn=Manager,dc=test, dc=com" -W
标签:[!--infotagslink--]

您可能感兴趣的文章: