Ó¦ÓÃIDS·ÀÖ¹SQL×¢Èë¹¥»÷
http://www.cnhacker.com/Hacker/Skills/200807/t20080731_6187.html
Ŀǰ£¬Õë¶ÔÓ¦Óü°Æäºǫ́Êý¾Ý¿âµÄÓ¦Óü¶ÈëÇÖÒѾ±äµÃÔ½À´Ô½²þâ±£¬ÈçSQL×¢Èë¡¢¿çÕ¾µã½Å±¾¹¥»÷ºÍδ¾ÊÚȨµÄÓû§·ÃÎʵȡ£ËùÓÐÕâЩÈëÇÖ¶¼ÓпÉÄÜÈÆ¹ýǰ̨°²È«ÏµÍ³²¢¶ÔÊý¾ÝÀ´Ô´·¢Æð¹¥»÷¡£
ΪÁ˶Ը¶ÕâÀàÍþв£¬ÐÂÒ»¼¶±ðµÄ°²È«ÍÑÓ±¶ø³ö£¬Õâ¾ÍÊÇÓ¦Óð²È«¡£ÕâÖÖ°²È«¼¼Êõ½«´«Í³µÄÍøÂçºÍ²Ù×÷ϵͳ¼¶ÈëÇÖ̽²âϵͳ(IDS)¸ÅÄîÓ¦ÓÃÓÚÊý¾Ý¿â(¼´Ó¦ÓÃ)¡£Óëͨ³£µÄÍøÂç»ò²Ù×÷ϵͳ½â¾ö·½°¸²»Í¬µÄÊÇ£¬Ó¦ÓÃIDSÌṩÖ÷¶¯µÄ¡¢Õë¶ÔSQLµÄ±£»¤ºÍ¼àÊÓ£¬¿ÉÒÔ±£»¤ÊýÒÔǧ¼ÆµÄÔ¤ÏȰü×°»ò×ÔÐпª·¢µÄWebÓ¦Óá£ÀýÈ磬ӦÓÃIDS¿ÉÒÔ¼àÊӺͷÀ»¤¹Ø¼üµÄÊý¾Ý£¬Ê¹ÄÇЩÕë¶ÔÊý¾Ý¿âµÄ¹¥»÷£¬È绺³åÇøÒç³öºÍWebÓ¦Óù¥»÷µÈÎÞ·¨¶ÔÊý¾Ý¿âÔì³ÉÕæÕýµÄË𺦣¬¶øÇÒÓ¦ÓÃIDS»¹¿ÉÒÔ¶ÔÕâЩʼþ½øÐÐÉó²é¡£
Ó¦Óð²È«ÓëÍøÂçºÍÖ÷»ú°²È«Ö®¼ä´æÔںܴóµÄÇø±ð¡£Ó¦ÓÃÊÇǧ²îÍò±ðµÄ£¬µ«¹¥»÷µÄÄ¿±ê×ÜÊÇÏàͬµÄ£¬Ò²¾ÍÊÇÈëÇÖÊý¾Ý¿â¡£ÓÉÓÚÓ¦ÓÃʹÓÃSQLÓëÊý¾Ý¿â½øÐÐͨÐÅ£¬Òò´ËºÃµÄÓ¦ÓÃIDSÓ¦µ±Äܹ»½âÎöSQL£¬²¢ÇÒÌṩһÖÖÄܹ»Àí½âÁ÷Á¿µÄÄÚÈÝ£¬ÇÒÓÖÄÜÓëÓ¦Óû®Çå½çÏߵĿ͹۱£»¤²ã¡£
¶àÊýÓ¦ÓÃIDS¶¼ÓÐÈý¸ö×é¼þ¡£µÚÒ»¸öÊÇ»ùÓÚÍøÂç»òÖ÷»úµÄ´«¸ÐÆ÷¡£ÍøÂç´«¸ÐÆ÷Á¬½Óµ½½»»»»úÉ쵀 ......
ÎÞÂÛÊÇʹÓÃÊÖ¹¤ÊÔ̽»¹ÊÇʹÓð²È«²âÊÔ¹¤¾ß£¬¶ñÒâ¹¥»÷Õß×ÜÊÇʹÓø÷ÖÖ¹î¼Æ´ÓÄãµÄ·À»ðǽÄÚ²¿ºÍÍⲿ¹¥ÆÆÄãµÄSQL·þÎñÆ÷ϵͳ¡£¼ÈÈ»ºÚ¿ÍÔÚ×öÕâÑùµÄÊÂÇé¡£ÄãÒ²ÐèҪʵʩͬÑùµÄ¹¥»÷À´¼ìÑéÄãµÄϵͳµÄ°²È«ÊµÁ¦¡£ÕâÊÇÀíËùµ±È»µÄ¡£ÏÂÃæÊǺڿͷÃÎʺ͹¥ÆÆÔËÐÐSQL·þÎñÆ÷µÄϵͳµÄÊ®ÖÖ¹î¼Æ¡£
1.ͨ¹ý»¥ÁªÍøÖ±½ÓÁ¬½Ó
ÕâЩÁ¬½Ó¿ÉÒÔÓÃÀ´¹¥»÷ûÓзÀ»ðǽ±£»¤¡¢È«ÊÀ½ç¶¼¿ÉÒÔ¿´µ½ºÍ·ÃÎʵÄSQL·þÎñÆ÷¡£DShield¹«Ë¾µÄ¶Ë¿Ú±¨¸æÏÔʾÁËÓжàÉÙϵͳÔÚÄÇÀïµÈ´ýÔâÊܹ¥»÷¡£ÎÒ²»Àí½âÔÊÐí´Ó»¥ÁªÍøÖ±½Ó·ÃÎÊÕâÖÖÖØÒªµÄ·þÎñÆ÷µÄÀíÓÉÊÇʲô¡£µ«ÊÇ£¬ÎÒÔÚÎ񵀮À¹ÀÖÐÈÔ·¢ÏÖÁËÕâÖÖ°²È«Â©¶´¡£ÎÒÃǶ¼¼ÇµÃSQL SlammerÈ䳿¶ÔÄÇÑù¶àµÄÓЩ¶´µÄSQL·þÎñÆ÷ϵͳÔì³ÉµÄÓ°Ïì¡£¶øÇÒ£¬ÕâЩֱ½ÓµÄ¹¥»÷Äܹ»µ¼Ö¾ܾø·þÎñ¹¥»÷¡¢»º´æÒç³öºÍÆäËü¹¥»÷¡£
2.°²È«Â©¶´É¨Ãè
°²È«Â©¶´É¨Ãèͨ³£¿ÉÒÔ»ù±¾µÄ²Ù×÷ϵͳ¡¢ÍøÂçÓ¦ÓóÌÐò»òÕßÊý¾Ý¿âϵͳ±¾ÉíµÄÈõµã¡£´ÓûÓÐʹÓÃSQL°²È«²¹¶¡¡¢»¥ÁªÍøÐÅÏ¢·þÎñ(IIS)ÉèÖÃÈõµãµ½SNMP(¼òµ¥ÍøÂç¹ÜÀíÐÒé)©¶´µÈÈκÎÊÂÇé¶¼Äܹ»±»¹¥»÷Õß·¢ÏÖ£¬²¢ÇÒµ¼ÖÂÊý¾Ý¿â±»¹¥ÆÆ¡£ÕâЩ»µµ°Ò²ÐèʹÓÿªÔ´Èí¼þ¡¢×Ô¼ºÖÆ×÷µÄ¹¤¾ßÈí¼þ»òÕßÉÌÒµÐÔ¹¤¾ßÈí¼þ¡£ÓÐЩ¼¼Êõ¸ßÊÖÉõÖÁÄܹ»ÔÚÃüÁîÌáʾ·ûÏÂʵʩÊÖ¹¤ºÚ¿Í¹¥»÷¡£ÎªÁ˽Úʡʱ¼ä£¬ÎÒ½¨ÒéʹÓÃÉÌÒµÐÔ ......
Ò».×¢ÊÍ
-- µ¥ÐÐ×¢ÊÍ£¬´ÓÕâµ½±¾ÐнáÊøÎª×¢ÊÍsql Óï·¨£¬ÀàËÆC++£¬c#ÖÐ//
/* … */ ¶àÐÐ×¢ÊÍ£¬ÀàËÆC++£¬C#ÖÐ/* … */
¶þ.±äÁ¿£¨int£¬ smallint£¬ tinyint£¬ decimal£¬float£¬real£¬ money £¬smallmoneysql Óï·¨£¬ text £¬image£¬ char£¬ varchar¡£¡£¡£¡£¡£¡££©
Óï·¨£º
DECLARE
{
{@local_variable data_type}
} [£¬...n]
ÀýÈ磺
declare @ID int --ÉêÃ÷Ò»¸öÃûΪ@IDµÄ±äÁ¿£¬ÀàÐÍΪintÐÍ
Èý.ÔÚSQL Server´°¿ÚÖдòÓ¡³ö±äÁ¿µÄÖµ
Óï·¨£º
PRINT 'any ASCII text' | @local_variable | @@FUNCTION | string_expr
ËÄ.±äÁ¿¸³Öµ
ÀýÈ磺
--´ÓÊý¾Ý±íÖÐÈ¡³öµÚÒ»ÐÐÊý¾ÝµÄID£¬¸³Öµ¸ø±äÁ¿@id£¬È»ºó´òÓ¡³öÀ´
Declare @ID int
Set @ID = (select top(1) categoryID from categories)
Print @ID
ÔÚSQLÖУ¬ÎÒÃDz»ÄÜÏñ´úÂëÄÇÑùÖ±½Ó¸ø±äÁ¿¸³Öµ£¬ÀýÈç@id = 1£¬Èç¹ûÒª´ïµ½ÕâÑùµÄ¹¦ÄÜ£¬¿ÉÒÔÕâÑùд£º
Declare @ID int
Set @ID = (select 1) -- ÀàËÆ @ID=1
Select @id=1 -- ÀàËÆ @ID=1
Print @ID
Îå.±äÁ¿ÔËËã(+£¬-£¬*sql Óï·¨£¬/£¬……)
ÒÔϱØÒªÊ±ºòÊ¡ÂÔ±äÁ¿ÉêÃ÷
Set @ID = (select 1+5) --ÀàËÆ @ID=1+5
Set @ID=(select 1-@ID) --ÀàËÆ @ID=1-@ID
Á ......
Ҫȷ¶¨ËùÔËÐÐµÄ SQL Server 2005 µÄ°æ±¾£¬ÇëʹÓà SQL Server Management Studio Á¬½Óµ½ SQL Server 2005£¬È»ºóÔËÐÐÒÔÏ Transact-SQL Óï¾ä£º
SELECT SERVERPROPERTY('productversion'), SERVERPROPERTY ('productlevel'), SERVERPROPERTY ('edition')
½á¹û£º
RTM 2005.90.1399
SQL Server 2005 Service Pack 1 2005.90.2047
SQL Server 2005 Service Pack 2 2005.90.3042
Ҫȷ¶¨ËùÔËÐÐµÄ SQL Server 2000 µÄ°æ±¾£¬ÇëʹÓòéѯ·ÖÎöÆ÷Á¬½Óµ½ SQL Server 2000£¬È»ºóÔËÐÐÏÂÁдúÂ룺
SELECT SERVERPROPERTY('productversion'), SERVERPROPERTY ('productlevel'), SERVERPROPERTY ('edition')
½á¹û£º
RTM 2000.80.194.0
SQL Server 2000 SP1 2000.80.384.0
SQL Server 2000 SP2 2000.80.534.0
SQL Server 2000 SP3 2000.80.760.0
SQL Server 2000 SP3a 2000.80.760.0
SQL Server 2000 SP4 2000.8.00.2039 ......
Èí¼þ £º Sql Server 2005
ÕâÀï²¢²»ÊÇSQLÓï·¨´óÈ«£¬ÒÔÏÂÊdz£ÓõÄÓï¾ä£¬¶Ô£¨Êý¾Ý¿â¡¢±í¡¢×ֶΡ¢Êý¾Ý£©µÄÔöɾ¸Ä²é£¬Èç¹ûÐèÒªÏêÏ¸È«ÃæµÄTransact-SQLÓï¾ä£¬¿ÉÒÔ²éSql ServerÁª»ú´ÔÊ飬ÄÇÀïÊÇ×îÈ«µÄ×ÊÁÏ£¬Ò»°ã°²×°Sql Server¶¼»áĬÈϰ²×°¡£
´ò¿ªSql ServerÁª»ú´ÔÊé
¿ªÊ¼ à ³ÌÐò à Microsoft SQL Server 2005 à ÎĵµÓë½Ì³Ì à Sql ServerÁª»ú´ÔÊé
´ò¿ªTransact – SQL²Î¿¼
Sql Server 2005 Áª»ú´ÔÊé à Sql Server ÓïÑԲο¼ à Transact – SQL²Î¿¼
Êý¾Ý¿â
´´½¨
create database TestDB
ÐÞ¸Ä
ALTER DATABASE TestDB MODIFY NAME = TestDataBase /* ÉÙʹÓÃ*/
²éѯËùÓÐ
SELECT Name from Master..SysDatabases ORDER BY Name /* Ò»°ãºÜÉÙʹÓÃ*/
ɾ³ý
drop database TestDB
±í
´´½¨
Create table house(
Rates int,
Grow int,
Place varchar(10),
Year int
)
²éѯËùÓÐ
SELECT Name from SysObjects Where ......
Ò»¸ö·Ç³£¼òµ¥µÄPHPÉú³ÉËõÂÔͼµÄ´úÂë³ÌÐò£¬²ÎÊý¼°´úÂë¶¼ËãµÃÉϾ«¼ò£¬ÓÐÐËȤµÄÅóÓÑ¿ÉÒÔÊÔÏÂËüµÄ¹¦ÄÜ£¬Óв»Ì«ÍêÉÆµÄµØ·½»¹ÇëÖ¸Õý¡£ ·ÇÔ´´£¬À´×ÔÍøÂç
<?$FILENAME="image_name";
// Éú³ÉͼƬµÄ¿í¶È
$RESIZEWIDTH=400;
// Éú³ÉͼƬµÄ¸ß¶È
$RESIZEHEIGHT=400;
function ResizeImage($im,$maxwidth,$maxheight,$name){
$width = imagesx($im);
$height = imagesy($im);
if(($maxwidth && $width > $maxwidth) || ($maxheight && $height > $maxheight)){
if($maxwidth && $width > $maxwidth){
$widthratio = $maxwidth/$width;
$RESIZEWIDTH=true;
}
if($maxheight && $height > $maxheight){
$heightratio = $maxheight/$height;
$RESIZEHEIGHT=true;
}
if($RESIZEWIDTH && $RESIZEHEIGHT){
if($widthratio < $heightratio){
$ratio = $widthratio;
}else{
$ratio = $heightratio;
}
}elseif($RESIZEWIDTH){
$ratio = $widthratio;
}elseif($RESIZEHEIGHT){
$ratio = $heightratio;
}
$newwidth = $width * $ratio;
$newheight = $height * $ratio;
if(function_exists("imagecopyre ......