php怎么取值范围,eeeeee代表什么颜色?
这种表示方式是十六进制,它的前两们是表示红色,中间两们是绿色,最后两们是蓝色,它的取值范围(0-9a-f)
如你说的#eeeeee就是浅灰色,它可以简写成#eee;
如果两位数值相同就可以用一个数值代替
如:#eeff66 -> #ef6
PHP如何将字符型转换成整形?
intval(PHP3,PHP4,PHP5)intval--获取变量的整数值描述intintval(mixedvar[,intbase])通过使用特定的进制转换(默认是十进制),返回变量var的integer数值。var可以是任何标量类型。intval()不能用于array或object。注:除非var参数是字符串,否则intval()的base参数不会有效果。参见floatval()、strval()、settype()和类型戏法。
定义符号常量的正确方式?
定义符号常量的一般格式:
CONST<常量标识符>=<常量>
说明:常量说明部分以关键字const开头, 后面的标识符为常量标识符,其中"="号后的常量为整数、实数、字符、 字符串(字符、字符串常量在后面章节中将作介绍)。而且,在常量说明部分可以将几个常量说明成符号常量,共用一个关键字"const"。
例如: 则在本程序中pi和zero作为符号常量,分别代表实数3.14159和整数0。也就是说,常量说明部分既定义了常量名及其值,又隐含定义了常量的类型。
关于符号常量,应注意下列几点:⑴符号常量一经定义,在程序的执行部分就只能使用该常量标识符,而不能修改其值。⑵使用符号常量比直接用数值更能体现"见名知义"的原则,也便于修改参数,故一个较好的程序中,应尽量使用符号常量,在执行部分基本上不出现直接常量。
php如何防止sql注入攻击?
为了防止sql注入攻击,首先要明白sql注入攻击是什么?然后再针对sql攻击特性去防止。
sql注入攻击就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。具体来说,它是利用现有应用程序,将(恶意的)SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。
其实,我们可以简单的理解SQL注入为:未对用户输入进行过滤,导致用户的一些输入在程序执行时,当做SQL语句的一部分进行执行,从而针对一些敏感操作:OR 1=1 或者 WHERE 1=1 这种条件的加入,使得我们本身的SQL逻辑被跳过执行。
从sql注入攻击的特性中,我们发现sql攻击主要是对sql语句或特定sql关键词进行改写,达到一种欺骗程序的方式,由此,我们只需要把这种欺骗限制的语法进行规范话控制,就能有效的防止sql注入。
那么在PHP中,可以通过简单的四种方法来有效防止SQL注入:
1、对用户的输入进行过滤处理后,在进行操作,如:addslashes()方法或者开启magic_quotes_gpc方法;
2、针对获取的数值型数据,进行二次转换,如intval(),floatval();
3、所有需进行数据库查询的变量都使用单引号(')包围;
4、使用PDO或mysqli来对数据库进行操作。
PHPJavaPythonC?
如果把编程语言比作国家的话:
PHP:巴西。拥有很多美好的事物,经常炫耀自己,但私底下其实非常保守。
Java:美国。乐观,强大,喜欢把麻烦事掩盖起来。
Python:荷兰。时髦,富有,平易近人,有吸引力,但并不是表现最佳的。
C:挪威。强势,动态,但无法令人感到激动。
C++:英国。强大,严谨,但并不擅长于干实事,逐渐被Java取代。
如果把编程语言比作车的话:
PHP:Oscar Mayer Wienermobile。外形奇特,难以驾驭,但每个人都想驾驭它。
Java:家庭旅行车。驾驶起来很容易,速度不会太快,不容易车毁人亡。
Python:适合初学者使用的车。可以无照驾驶,适合在路况好、车速<30码的地方行驶。
C:赛车。跑得很快,但它可能每50公里就抛锚一次。
C++:C赛车的升级版。它除了拥有C赛车的功能,还增加了许多新功能。例如它每250公里只抛锚一次,但是一旦它抛锚,基本上没人能找出是什么地方出了错。
--------------------------------以下是几种语言的特点-----------------
PHP
优点:
1. 跨平台,性能优越
跟Linux/Unix结合比跟Windows结合性能强45%,并且和很多免费的平台结合非常省钱。
2. 语法简单,容易上手
PHP有成熟的开发工具,比如NuPHPed,在Linux平台下可以使用Eclipse等等。
3. 技术支持性好
很多技术工具,比如WebService、Ajax、XML等等,足够应用;还能够使用多种数据抽象层,模板层,方法。
4.框架多且成熟
比如支持MVC的框架:phpMVC,支持类似http://ASP.net的事件驱动的框架:Prado,支持类似Ruby On Rails的快速开发的框架:Cake等等,足够满足你的应用需求。
5.面向对象体系,能够适应基本的面向对象要求。适合开发大型项目。
6..开源性
比如比较知名的开源框架有Zend Framework、CakePHP、CodeIgniter、symfony等,开源论坛有Discuz!、Phpwind等,开源博客 WordPress,开源网店系统如Ecshop、ShopEx等,开源的SNS系统如UCHome、ThinkSNS等。
缺点:
1.对多线程支持不太好,大多数时候我们只能简单的模拟去实现的。
2.语法不太严谨,比如变量不需要定义就可以使用,在c,Java,c++中变量是必须先定义以后才可以使用的。
3. PHP的解释运行机制繁琐。
Python
优点
1.易于学习
python虽然是用c语言写的,但是它摈弃了c中非常复杂的指针,简化了python的语法,它使你能够专注于解决问题而不是去搞明白语言本身。
2.开源性
Python是FLOSS(自由/开放源码软件)之一,Python希望看到一个更加优秀的人创造并经常改进。
3.可移植性
Python经过改动,已经被移植在许多平台上了。另外,Python解释器把源代码转换成称为字节码的中间形式,然后再把它翻译成计算机使用的机器语言并运行,因而,你只需要把你的Python程序拷贝到另外一台计算机上,它就可以工作了,这也使得你的Python程序更加易于移植。
4.面向对象面向过程同时支持。
5.可扩展性和可嵌入性
你可以将Python嵌入到C/C++程序,让你的程序的用户获得"脚本化"的能力。
6.标准库以及第三方库资源丰富
Python标准库确实很庞大。python有可定义的第三方库可以使用。它可以帮助你处理各种工作,包括正则表达式、文档生成、单元测试、线程、数据库、网页浏览器、CGI、FTP、电子邮件、XML、XML-RPC、HTML、WAV文件、密码系统、GUI(图形用户界面)等等。
缺点
1.运行速度慢,相比于C++/C运行速度偏慢,不过对于用户而言,机器上运行速度是可以忽略的。
2.构架选择太繁杂,没有像C#这样的官方.net构架,也没有像ruby由于历史较短,构架开发的相对集中,所以人人都有不同的方案。
Java
优点:
1. 跨平台性
Java语言中, Java自带的虚拟机很好地实现了跨平台性。 Java虚拟机提供了一个字节码到底层硬件平台及操作系统的屏障,使得Java语言具备跨平台性。
2. 面向对象
Java是一种面向对象的语言,也继承了面向对象的诸多好处,如代码扩展、代码复用等。
3. 安全性
运行时Java类需要类加载器载入,并经由字节码校验器校验之后才可以运行。 Java类在网络上使用时,对它的权限进行了设置,保证了被访问用户的安全性。
4. 多线程
Java除了内置的多线程技术之外,还定义了一些类、方法等来建立和管理用户定义的多线程。
5. 简单易用
Java源代码的书写不拘泥于特定的环境,可以用记事本、文本编辑器等编辑软件来实现,然后将源文件进行编译,编译通过后可直接运行,通过调试则可得到想要的结果。
缺点:
运行速度相比于C/C++有些缓慢了,这是机制原因导致的。
C
优点:
1. 简洁紧凑、灵活方便
C语言一共只有32个关键字,9种控制语句,程序书写自由,主要用小写字母表示。它把高级语言的基本结构和语句与低级语言的实用性结合起来。 C 语言可以象汇编语言一样对位、字节和地址进行操作, 而这三者是计算机最基本的工作单元。
2. 运算符丰富
C的运算符包含的范围很广泛,共有种34个运算符。C语言把括号、赋值、强制类型转换等都作为运算符处理。从而使C的运算类型极其丰富表达式类型多样化,灵活使用各种运算符可以实现在其它高级语言中难以实现的运算。
3. 数据结构丰富
C的数据类型有:整型、实型、字符型、数组类型、指针类型、结构体类型、共用体类型等。能用来实现各种复杂的数据类型的运算。并引入了指针概念,使程序效率更高。另外C语言具有强大的图形功能, 支持多种显示器和驱动器。且计算功能、逻辑判断功能强大。
4.C是结构式语言
结构式语言的显著特点是代码及数据的分隔化,即程序的各个部分除了必要的信息交流外彼此独立。这种结构化方式可使程序层次清晰, 便于使用、维护以及调试。C语言是以函数形式提供给用户的,这些函数可方便的调用,并具有多种循环、条件语句控制程序流向,从而使程序完全结构化。
5. C语法限制不太严格、程序设计自由度大
一般的高级语言语法检查比较严,能够检查出几乎所有的语法错误。而C语言允许程序编写者有较大的自由度。
6. C能直接访问物理地址和操作硬件
因此既具有高级语言的功能,又具有低级语言的许多功能,能够象汇编语言一样对位、字节和地址进行操作,而这三者是计算机最基本的工作单元,可以用来写系统软件。
7. C语言程序生成代码质量高
程序执行效率高一般只比汇编程序生成的目标代码效率低10へ20%。
8. C语言适用范围大,可移植性好
C语言有一个突出的优点就是适合于多种操作系统, 如DOS、UNIX,也适用于多种机型。
另外
C语言具有绘图能力强,可移植性,并具备很强的数据处理能力,因此适于编写系统软件,三维,二维图形和动画它是数值计算的高级语言。
缺点:
运算符和运算优先级过多,不便于记忆,语法定义不严格,编程自由度大,对新手不友好。
C++
C++除了兼具了C语言的优势之外,还有一下特点:
C++语言的主要特点表现在两个方面,一是尽量兼容C,二是支持面向对象的方法。
它操持了C的简洁、高效的接近汇编语言等特点,对C的类型系统进行了改革的扩充,因此C++比C更安全,C++的编译系统能检查出更多的类型错误。
另外,由于C语言的广泛使用,因而极大的促进了C++的普及和推广。C++语言最有意义的方面是支持面向对象的特征。虽然与C的兼容使得C++具有双重特点,但他在概念上完全与C不同,更具面向对象的特征。
出于保证语言的简洁和运行高效等方面的考虑,C++的很多特性都是以库(如STL)或其他的形式提供的,而没有直接添加到语言本身里。C++引入了面向对象的概念,使得开发人机交互类型的应用程序更为简单、快捷。很多优秀的程序框架包括Boost、Qt、MFC、OWL、wxWidgets、WTL就是使用的C++。
欢迎关注我的微信公众号:九章算法(ninechapter),帮助你了解IT技术前沿,通过面试、拿到offer、找到好工作!