Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
12
Добавлен:
20.04.2024
Размер:
32.48 Mб
Скачать

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

 

 

C

 

E

 

 

 

 

 

X

 

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

 

F

 

 

 

 

 

 

t

 

 

 

D

 

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

>> codingw Click

 

BUY

 

 

 

to

 

 

 

 

m

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

o

 

 

 

.

 

 

 

 

 

 

.c

 

 

 

 

p

 

 

 

 

g

 

 

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

 

 

-x cha

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Компилируем

Процесс отладки

Покодим!

Настало время реализации практической части. Итак, открываем Xcode, создаем проект, основанный на флип-окне. Где ресурсы, где код, а где хедеры — разобрался? Молодец! Конечно же, главный файл проекта имеет расширение .xcodeproj, файлы с кодом — расширение .m, заголовки с расширением .h ты точно узнал, а .xib — что-то вроде скомпиленого класса, в нем могут быть строки, формы да и сам код класса. Часть кода ты делаешь ручками, а часть — автоматом через Interface Builder. Так вот, автоматическая часть сюда и упаковывается.

Как добавлять картинку и перетянуть ее на форму — тебя учить не нужно, если непонятно — смотри скриншоты. Редактируется все интуитивным мышиным кликом. Что ж, компилируем.

Для запуска приложения выбираем целевое устройство и рабочую версию SDK. Создавать приложения лучше для iPhone 2.0, так как в 2.1 есть некоторые фишки, лишенные обратной совместимости с 2.0, отягощенным более старыми версиями прошивки.

Полюбовался, работает? Теперь можно покопаться в коде. У любой программы точка входа находится в файле main.m (функция main). В ней выделяется память для объектов с дефолтным деструктором (надо же их за тобой как-то убирать) и создается шаблон приложения высшего уровня вместе с ключевыми объектами (функция UIApplicationMain). Приложения для iPhone однопоточные, поэтому выход из этой функции означает завершение программы:

int main(int argc, char *argv[])

{

NSAutoreleasePool * pool =

\ [[NSAutoreleasePool alloc] init]; int retVal = UIApplicationMain

\(argc, argv, nil, nil);

Любуемся!

Редактируем два экрана для основного вида и для обратного

[pool release];

return retVal;

}

Далее разберем такое понятие, как Application Delegate. Это нечто вроде базового класса для твоей программы (в примерах он уже создан). Интерфейс главного делегата описан в HelloWorldAppDelegate.h,

а тело — положено в HelloWorldAppDelegate.m.

Такого понятия, как вызов метода другого класса, в Objective-C нет, все делается через делегаты и сообщения. То есть, ты посылаешь объекту сообщение, и если целевой класс его сумеет обработать — считай, что своего ты добился. К примеру, Application Delegate связан с UIApplication, именно он создает окно, интерфейс пользователя, отвечает за прерывания, сообщения акселерометра и прочее.

(void)applicationDidFinishLaunching:(UIApplication *) application {

// создаем контроллер видов

MyViewController *aViewController = [[MyViewController alloc] initWithNibName:@ "HelloWorld" bundle:[NSBundle mainBundle]]; self.myViewController = aViewController;

//Квадратные скобки — это и есть отправление сообщения

//В данном случае объекту aViewController

//отправляется сообщение release

[aViewController release]; [[UIApplication sharedApplication]

setStatusBarStyle:UIStatusBarStyleBlackOpaque]; // Каждый вид контроллера является подвидом окна

UIView *controllersView = [myViewController view];

xàêåð 12 /120/ 08

091

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

 

C

 

E

 

 

 

 

 

X

 

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

>>m

 

w Click

to

 

 

 

 

coding

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

ВладимирКузнецов,ведущийiPhone developerкомпанииCactusSoft

Чтобы тебе было легче представить свое вероятное будущее, мы расспросили ведущего iPhone developer’а компании CactusSoft про особенности и трудности программирования для девайса Apple. Владимир Кузнецов, в миру более известный как Real (с некоторых пор

— iReal), около пяти лет зарабатывал на бутерброд с икрой скилами С++ и C# (из них 3 года — С++ на уровне девелопера), а недавно решил все бросить и повернулся в сторону йаМобилки, очаровал менеджера и с ходу попал на должность лидирующего разработчика. Он уже успел пообщаться с реальными заказчиками, провести пару собеседований при приеме на работу, поучаствовать в крупных проектах для iPhone. В общем, камрад правильный, дурного не посоветует.

Рил,расскажи,вкакихпроектахтыучаствовал, чтописалсам?

Начал с простого приложения для работы с микроблоггингом. Дальше началось интересное — программа для управления термостатом. У заказчика в США есть такая штука, которая управляет множеством систем контроля температуры. В ней есть свой http-сервер. Моя программа к нему присоединяется и управляет всей этой махиной, снимает текущие данные, позволяет настраивать новые. Сейчас они захотели более навороченную версию, но это уже не мой проект. Я в данный момент занимаюсь разработкой игрового движка. В целях переносимости кода на другие платформы в качестве основного языка был выбран C++. В местах, более привязанных к конкретной платформе, для iPhone-версии будет использован Objective-C. Кроме этого, есть еще несколько параллельных небольших проектов под iPhone.

Внушительно.Ладно,верим,тыдостаточнокрут.Адоэтого тыневозилсясМакамиипрочейпродукциейApple,верно?

ванного подхода. При программировании под iPhone довольно часто встречаешься с паттернами (делегаты, MVC, синглетон). Соответственно, необходимы определенные знания в C++, хорошее понимание принципов ООП, надо быть хотя бы знакомым с паттернами. Ну а в идеале — иметь хороший опыт программирования для компьютеров Apple; язык, фактически, тот же, только некоторые классы отличаются.

Опыткакогоязыкатебепригодился? НачтопохожияблочныеСи?

На C, C++, C#. На что же еще им быть похожими? В большей степени понадобился опыт C++, он фактически является прототипом Objective- C. Более того, возможно комбинирование кода C++ и Objective-C в рамках одного проекта и даже класса.

ЛегколибылопереходитьнаифоновскиеСи?

Поначалу даже трудно, ибо слишком много нового: другая операционная система, другая раскладка клавиатуры, другие горячие клавиши, другой синтаксис, много новых ключевых слов, терминология, которая противоположно пересекается с C# (например, то, что в C# называется интерфейсом, в Objective-C зовется протоколом, интерфейс же там применяется несколько в другом роде). Другая и логика внутренней архитектуры приложений (например, все классы обмениваются информацией через посылку сообщений). Но при наличии желания, стремления и усилий к этому всему очень быстро привыкаешь.

Чтонравитсявязыке,вособенностях программингадляифона?

Да, с Маками особо поиграться не довелось, зато сейчас мне директор подарил iPod touch и MacBook. Для работы, конечно же, хотя я и забираю обе игрушки с собой домой.

Кактысходуперешелнановыйязык,счегоначинал?

Начиналсосвоения147старницмануалаObjective-C2.0Programming Language,далеепросмотрел212страницiPhoneOSProgrammingGuide.

Всего-то:).Впринципе,дляработыэтогоужедостаточно,остальное будетизучатьсявпроцессепрактики.Адляначалавообщехватитпросто ознакомитьсяспримерами,посмотретьвидеоурокинасайтеApple— и можноначинать.Яимеюввидунезеленыхкодеров,аребятсмозгом.

Нуда,нашичитателиименнотакие.Чтовообщенужно знать,какаяминимальнаябазазнанийдолжнабыть,чтобы занятьсякодингомдлягаджетаApple?

Objective-C — это расширение C++ в сторону объектно-ориентиро-

[window addSubview:controllersView]; [window makeKeyAndVisible]; }

MyViewController.m— файл с кодом, собственно, контроллера нашего главного элемента формы. В нем содержится функционал этого приложения. Файл подробно прокомментирован и выложен на нашем DVD, поэтому не забудь глянуть.

Мы добавили новый контрол для переворота экрана, а исходники для него и смежных классов сгенерились автоматически. Главный вид — FlipsideView, сюда вложены RootViewController(он управляет переворотами окошек, анимацией) и два вида — обратный,

Нравится новый опыт. Люблю копаться в чем-то новом. Язык нравится, Objective-C «заставляет» мыслить более объектно. Простые iPhone-приложения на пару экранов делаются довольно легко, да еще и обладают всеми графическими красивостями, свойственными телефону Apple. Красиво и удобно.

Наверное, только общаясь с творениями Apple, понимаешь, насколько непродуман интерфейс у Microsoft и начинаешь сам создавать более грамотные интерфейсы, стараться улучшать юзабилити своих программ.

ТыпробовалнеофициальныйСДК?Гдепрограммитьудобнее,вофициальномиливнеофициальном?

Неофициальный SDK — хлам, с помощью которого кое-как можно работать. C их помощью нельзя писать полноценные легальные приложения под iPhone. Самому, к счастью, с этим столкнуться не пришлось.

Я работаю с Apple iPhone SDK.

FlipsideView, и прямой — MainView. RootViewController

определяет, какой из видов надо отобразить. Именно ему отправляются сообщения о смене вида. В результате, мы получили (и разобрались в устройстве) пример крайне простой, но работающей программки всего лишь с помощью нескольких щелчков мышью в среде разработки. На врезке ты можешь увидеть интервью с настоящим гуру айфон-кодинга, а мне же позволь откланяться. Будем надеяться, мы продолжим знакомство с гламурным кодингом под яблочный телефон в следующих номерах ][акера. Не стесняйся, пиши свои просьбы и отзывы — от твоих писем зависят те темы, которые мы будем раскрывать в статьях. z

092

xàêåð 12 /120/ 08

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

>>m

 

w Click

to

 

 

 

coding

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

Юрий «yurembo» Язев

/ yazevsoft@gmail.com /

Темноеискусство игродела,часть 3

Однопользовательская игра: достижение абсолюта

Сегодня мы закончим разрабатывать однопользовательскую игру, доведя ее до совершенства. Добавим и реализуем пару классов, подключим несколько звуков (для поддержки геймплея), рассмотрим работу с дополнительными функциями и типами объектов библиотеки Dark GDK — и сделаем еще много интересного.

Объектыигровогомира

СзаголовочнымфайломGame_Obj.hмывстретилисьещевпрошлойста- тье,ноиз-зажесткихограничений(впланеразмеровжурнала)нампри- шлосьотложитьегорассмотрениедолучшихвремен.Ионинаступили!

Этот заголовочный файл содержит объявления всех констант, используемых в игре, как то: объекты, текстуры, звуки и параметры экрана. Все эти константы числовые (если помнишь, ранее я говорил о том, что все типы объектов в Dark GDK представляются в виде чисел). Кроме объявления констант, файл содержит описание абстрактного супер-класса (в терминах Java и в C++ это будет просто базовый класс). Как и полагается, этот класс содержит минимум необходимых данных-членов и функций-членов, используемых всеми производными классами. Это такие переменные, как: номер текущего объекта, положение объекта в трехмерном пространстве по осям x, y, z, угол поворота (только по оси Y), индикаторы жизни и горения (переменные булевого типа) и переменная для хранения времени. Многие функции

не только объявлены, но имеют реализацию прямо в заголовочном файле, что автоматически делает их встраиваемыми. Действительно, если функция выполняет одну единственную инструкцию, то почему бы не реализовать ее прямо здесь? Использование встраиваемых функций уменьшает необходимость в препроцессоре — экономятся ресурсы, связанные с вызовом функции. Эти функции выполняют такие операции, как: возвращение номера текущего объекта, возвращение состояния (жив или мертв, горит или нет), возвращение позиции, возвращение угла поворота. Все перечисленные функции-члены не изменяют (и не должны изменять) своего поведения во всех клас- сах-потомках, поэтому работают они одинаковым образом, прямо как программист-проектировщик прописал. Еще в описании интерфейса класса имеются объявления трех виртуальных функций, плюс деструктор (тоже виртуальный). В нашей программе деструктор можно было и не делать виртуальным, поскольку в ней не используются указатели на объекты классов-предков. Но yurembo (если кто не догадался,

094

xàêåð 12 /120/ 08

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

>> codingw Click

 

BUY

 

 

to

 

 

 

 

m

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

Проигрыш

 

автор любит обращаться к себе в третьем лице, —

 

 

 

 

Прим. ред.) решил не отходить от привычного стиля про-

 

 

 

 

граммирования и не отказываться от советов мастеров

 

 

 

 

ООП. Да, кстати, деструктор сделан чисто виртуальным

 

 

 

Мы победили!

 

(или абстрактным). Ну да хватит о деструкторах, перейдем

 

 

 

 

к трем сакраментальным виртуальным функциям:

из любого места программы. Это общепринятый подход

 

1)Функция Draw(), производящая манипуляции над

создания интерфейса с классом: данные-члены недоступны

 

объектом, ее вызвавшим (перемещение, поворот, etc).

извне функций данного класса, а вся работа с объектом про-

 

Несмотря на название (Draw), она не отображает объект;

исходит через его функции-члены. Подчеркну: только в этом

 

воспроизведение сцены происходит после того, как все

файле (Game_Obj.h) подключается заголовочный файл

 

объекты будут размещены, а потом в глобальной функции

библиотеки DarkGDK.h, а все остальные файлы проекта

 

перерисовки вызывается функция библиотеки Dark GDK,

подключают уже наш файл — Game_Obj.h.

 

которая и отобразит сцену на экране. Объявлена она вирту-

 

 

 

 

альной по той причине, что в классах-потомках переписы-

 

Ракеты

 

 

 

 

 

вается не только тело функции, но и прототип (изменяются

Взглянем на следующий заголовочный файл — Rocket.h.

 

передающиеся в нее параметры).

В этом файле мало кода, и нет ничего сложного. Как и следу-

 

2)Функция PlaySound (), как и следует из ее названия,

ет из названия, в нем содержится описание класса игровых

 

проигрываетзвук(и) данного объекта, поэтому она исделана

ракет, используемых как пользовательским роботом, так и

 

виртуальной: в каких-то классах надо будет передавать звук

врагами. Класс ракет наследует от рассмотренного выше

 

в качестве параметра (где может быть несколько звуков); ну

основного класса игровых объектов все данные-члены и

 

а в тех классах, где имеется только один звук, параметров у

функции-члены, тем самым, приобретая всю его функци-

 

этой функции нет. Кроме того, в некоторых классах-потомках

ональность. Этот подход дарует нам множество плюсов. К

 

в эту функцию в качестве параметров передаются коорди-

примеру, код, написанный однажды (для класса-предка),

 

наты источника звука, но пока не будем об этом.

используется всегда одинаково (во всех классах-потомках).

 

3)Последняя виртуальная функция-член — Die()объ-

Кстати, почитай любую хорошую книгу по ООП! Здесь и в

 

явлена как чисто виртуальная ввиду того, что она должна

остальных наследующих классах наследование открытое

 

быть реализована в каждом классе-потомке без изменения

(public; если при наследовании не указать спецификатор

 

прототипа. Замечу, что компилятор не выдает никаких

доступа, то по умолчанию будет закрытое наследование,

 

сообщений, если в классе-предке объявить невиртуальную

private) — мы ведь не хотим, чтобы открытые функции-члены

 

функцию, а затем переопределить ее в классе-потомке. Та-

в наследующем классе стали недоступными (закрытыми).

 

ким образом, мы столкнемся с неоднозначностью, которая

Заметь, в этом классе не добавляется ни одна переменная,

 

заключается в вызове нужной функции: может быть вызвана

переопределяются все виртуальные функции (включая

 

совсем не та функция, вызов которой ожидается! Поэтому

деструктор), объявляются два конструктора: по умолчанию

 

 

необходимость ключевого слова virtual очень существенна.

и с параметрами, а также объявляются две отсутствующие в

 

Вообще, компилятор, в принципе, не может (и не должен)

классе-предке функции.

 

указывать на неявные ошибки при использовании модели

 

 

 

 

ООП. Кстати, он этого и не делает, потому что он не пророк и

 

Взрывы

 

не может знать, о чем думает и к какой цели стремится про-

В рамках этого раздела мы перейдем к третьему заголо-

 

граммист. В определенных случаях «огрызается» линков-

вочному файлу — Explode.h, содержащему описание

 

щик, сообщая об ошибках на только ему понятном наречии

класса взрывов. Этот класс тоже наследуется от GameObj,

 

и выдавая довольно странную абракадабру, состоящую из

приобретая его функциональность; как и класс ракет, он

 

имен заголовочных файлов и функций :).

определяет два конструктора (конструкторы вообще по ряду

 

Обрати внимание, каким образом yurembo объявил данные-

причин никогда не наследуются :)). Переопределяются две

 

члены и функции-члены. Все данные-члены объявлены со

виртуальные функции и деструктор. Третья виртуальная

 

спецификатором доступа protected, который делает их ви-

функция в этом классе не используется, такое возможно,

 

димыми для функций-членов этого класса (что не так важ-

так как в базовом классе она объявлена с ключевым словом

 

но), а также видимыми для функций-членов производных

virtual (попросту говоря, виртуальна). Две объявляемых

 

классов. С другой стороны, все функции-члены объявлены

функции имеют то же имя, что и в классе ракет, — они

 

со спецификатором public, который делает их доступными

различаются только количеством (и типом) параметров. В

 

 

 

 

 

info

Если тема тебя заинтересовала, сообщи об этом автору, продолжим развитие хакерского игропрома.

xàêåð 12 /120/ 08

095

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

 

C

 

E

 

 

 

 

 

X

 

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

>>m

 

w Click

to

 

 

 

 

coding

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

Обозреватель решения (как и проект в целом) дополнился новыми файлами

 

таком случае можно было бы их объявить в базовом классе

 

виртуальными, но yurembo этого не сделал. Почему? Ведь

 

они не используются в классе роботов. Это, впрочем, можно

 

сказать и о функции-члене PlaySound (третья виртуальная

 

функция, неиспользуемая в классе взрывов, но используе-

dvd

мая во всех других классах). Но здесь только одна функция,

На диске лежит

и автор решил сделать виртуальной лучше ее, чем тащить в

полный исходный код

и без того большой класс роботов неиспользуемый функци-

финальной версии

онал (две рассмотренные выше функции, которые объявля-

однопользователь-

ются в двух производных классах).

ской игры DarkRobot,

 

 

для компиляции кото-

 

Реализация:ракеты

 

 

рого нужны: Visual

Первый по установленному нами порядку класс — это

C++ 2008 Express

Rocket (соответственно, его реализация находится в

Edition, DirectX 9.0

файле Rocket.cpp). После подключения заголовочного

SDK, Dark GDK.

файла в нем идут два конструктора: первый (тот, который

 

по умолчанию) не используется в нашей программе, но

 

должен формально присутствовать — во избежание ошибок

 

компиляции. Формален он потому, что имеет пустое тело во

 

избежание ошибок линковщика. В конструктор с пара-

 

метрами в качестве значений параметров передаются

 

инициализирующие объект данные, которые и присваи-

 

ваются данным-членам вновь создаваемой ракеты. Почти

 

все используемые здесь функции библиотеки Dark GDK

 

нами уже рассмотрены, поэтому не будем повторяться. Хотя

 

стоп, одна не рассмотрена — dbCloneObject! Она ведет

 

себя в полном соответствии с названием, клонируя объект.

 

Взгляни на условный оператор в конструкторе: если ракета

 

№ 1, то загружаем ее из файла, а все последующие копируем

спервой, так как они одинаковы. Таким образом, сокращается время загрузки: вместо того, чтобы загружать с диска все ракеты, грузится одна, а остальные быстро копируются

снее в оперативной памяти. Именно в оперативной, а не в видео — в последней хранятся только визуализированные сцены, готовые к выводу на экран. После создания объекта он скрывается (с помощью функции dbHideObject) и деактивируется, чтобы быть готовым появиться во время выстрела (функция Fire, — смотри ниже). Далее идет деструктор, который делает то, что ему и полагается: обнуляет все данные-члены, плюс функцией dbDeleteObject удаляет загруженный объект. Следующая функция Drawвовсе не отображает объект. Она вызывается при перерисовке (на каждом кадре) и производит различные манипуляции над объектом, в том числе, проверку столкновения ракеты с поверхностью ландшафта.

Функция Fire представляет собой место «рождения» ракеты, в ней вызываются функции проигрывания звука и позиционирования (к месту выстрела) ракеты. Функция Pos делает то, что и должна, — то есть перемещает ракету в пространстве к месту старта (выстрела). Предпоследняя функция Die не уничтожает ракету, а просто делает ее невидимой и неактивной, чтобы не пришлось снова загружать ее при следующем выстреле (в целях ускорения игрового движка и процесса). Однако, в таком раскладе есть и минусы: расходуется память, но если посмотреть на комплектацию современного (или даже морально устаревшего) компьютера, то мы в подавляющем большинстве обнаружим не менее 512 Мб оперативки, а на машинах геймеров — не ниже 1 Гб. Поэтому автор решил пожертвовать оперативкой в пользу скорости работы, ведь игры не могут быть тормознутыми, а если таковые найдутся — пиши пропало. Последняя в этом файле функция PlaySound выполняет два действия: позиционирует (в координаты, переданные в качестве параметров) источник звука и, собственно, проигрывает звук (также переданный в качестве параметра).

Взрывы

Класс Explode, содержащийся в файле Explode.cpp, представляет взрывы и вообще крайне интересен для нас, поскольку в нем реализуется новый (ранее не используемый нами) тип объектов — частицы. Но обо всем по порядку. Сначала, когда у автора возникла идея добавить в игру взрывы, он полез в интернет, чтобы нагуглить анимированные х-файлы с огнем (загружаемые нашим движком). Обнаружилось, что таких файлов приемлемого качества

вСети нема. Попытка смоделить анимированный огонь в любимой trueSpace также не увенчалась успехом: частицы наотрез отказались экспортироваться в х-файл. Тогда, у автора возникла идея: если частицы не экспортируются

вх-файл, то их надо создать в самой программе. В DirectX есть такая возможность. Yurembo уже собрался кодить под голый DirectX (со всеми вытекающими отсюда трудностями), как внезапно наткнулся на функцию с очень заманчивым названием — dbMakeParticles. Отсюда он и начал «плясать» :). Здесь мы приведем обзор кода из указанного файла, одновременно останавливаясь на новых функциях. Итак, в начале имеют место два конструктора: один из них пустой (который по умолчанию), а второй — инициализирует систему частиц. В нем есть три новые для нас функции. Во-первых, нам надо создать систему частиц в виде огня. Пожалуйста, в Dark GDK для этого есть специальная функция — dbMakeFireParticles. Ей передаются девять параметров: число, под которым сохранится создаваемая

096

xàêåð 12 /120/ 08

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

>> codingw Click

 

BUY

 

 

to

 

 

 

 

m

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

система (в нашем случае — это константа, которая передается в конструктор в качестве параметра). Заметь, частицы — относятся к другому типу объектов, из чего следует, что и нумерация у них своя.

Второйпараметр—номеризображения,котороебудетиспользоваться,как искра.Врезультате,нетруднодогадаться,получитсямножествотакихискр. Внашейпрограммеэтимпараметромпередаетсячисловаяконстанта,за которойзагруженомаленькоеквадратноеизображение(20х20).Онопредставляетсобойкрасныйквадрат,посредикоторогонарисованжелтыйкруг. Издалекаогонь-фонтанизтакихискороквыглядиточеньэффектно! Третий параметр — частота частиц (искр). Не стоит задавать слишком большое число, иначе время загрузки игры возрастет. Разумной кажется цифра в 3000.

Следующая тройка параметра задает положение системы частиц в пространстве. Последние три параметра задают, соответственно, ширину, высоту и глубину — то есть размеры по осям X, Y, Z. Функцией dbHideParticles мы скрываем систему частиц. Причины такого взаимодействия с объектом подробно рассмотрены в предыдущем разделе. Последней вызывается функция dbPositionParticles, которая перемещает частицы в заданные координаты. Впрочем, все координаты нулевые. Со взрывами — такая же история, что и с ракетами: при загрузке мы создаем все взрывы, а во время игры показываем и скрываем их, когда надо. После конструкторов идет деструктор, очищающий все данные-члены. Далее следует функция Draw, которая, как и в прошлый раз, позиционирует объект в пространстве, одновременно отвечая за отображение (при равенстве переменной alive значению true) и скрытие (в противоположном случае, который наступает по истечению 999 мс после появления) взрыва. Функция Die скрывает взрыв (подробно рассмотрена выше). Следующая за ней функция Fire занимается реинициализацией взрывов во время игры. И, наконец, последняя функция Pos позиционирует взрыв по переданным координатам, вызывая рассмотренную ранее функцию dbPositionParticles.

Главныйфайлреализации

Вфункции инициализации по сравнению с прошлым примером ничего не изменилось. Но в главный файл реализации добавилась новая функция, название которой — BSOD — расшифровывается, как Black Screen Of Death. Она вызывается по окончанию игры, в двух равновероятных случаях: проигрыш или выигрыш (смотри картинки).

Передаваемое в качестве параметра значение — по сути, индикатор различия победы и поражения. Благодаря этой функции, в финале игры будут представлены разные звуки и изображения. Кроме того, она выводит текст, осведомляющий геймера, что нужно сделать для продолжения. Она же выполняет обработку пользовательского ввода, соответствующего ее рекомендациям.

Вфункции DarkGDK() кроме создания роботов происходит создание всех остальных динамических объектов: ракеты, взрывы. Из-за того, что теперь в игре участвуют новые объекты, код главного цикла заметно вырос и требует обратить на себя внимание. Сперва мы запускаем цикл (их будет здесь множество) по вражеским роботам, в котором проверяем их состояние: если механический упырь уже «отбросил кони», а его ракета запущена, то уничтожаем ее, заодно увеличив значение переменной, заботливо учитывающей число погибших врагов. После этого цикла выполняется проверка, выясняющая, победил ли юзер. В

ней, кроме прочего, участвует упоминавшаяся выше скорбная переменная. Если количество мертвых механизмов из этой самой переменной оказывается равным количеству врагов в общей сложности, — победа засчитывается игроку и нам становится необходимо подчистить ресурсы и перевести пользователя на экран победы (вызвать BSOD :)). Ресурсы подчищаются только за динамическими объектами, для этого явно вызываются деструкторы наших классов. Остальные же объекты оставляются в покое, чтобы не возникло потом необходимости пересоздавать их перед началом новой игры.

После этого идут проверки и манипуляции с главным персонажем, которые были рассмотрены в прошлой статье. Однако и здесь есть

xàêåð 12 /120/ 08

Игровой процесс

свои новинки — это код, в результате выполнения которого геймерский робот осуществляет залп огня. Затем, как обсуждалось в прошлой статье, идут циклы проверки столкновений между роботами. После этих циклов следует новая проверка, которая на этот раз осуществляется для выяснения: не погиб ли под обстрелом юзверский робот? И если да, то выполняется код, аналогичный коду конца игры. Затем снова начинаются циклы, в которых на этот раз осуществляются манипуляции над ракетами: выполняется проверка на столкновения между ними и, собственно, мишенями — роботами. В результате вызываются их (ракет) функции-члены. Под конец осуществляет свою работу еще один цикл, в теле которого происходит обновление взрывов. Взрывы, кстати, создаются тогда и в том месте, когда и где объект (ракета, робот) принимает состояние горения (burn).

Закатсолнцавручную

В конце программы ресурсы, занятые объектами наших классов, освобождаются автоматически — мы создали объекты в стеке, и когда объект выходит из области видимости, то автоматически вызывается деструктор определенного класса, который выполняет предписанные ему действия — очищает память, удаляя объект.

Но кроме объектов наших классов, в программе мы создали объекты, не принадлежащие тому или иному самописному классу. И хотя в Dark GDK присутствуют функции для удаления объектов любого типа (3D-объекты, текстуры, звуки, etc), при завершении программы вызывать их не надо. Библиотека сама позаботится об очистке ресурсов, занятых ее объектами. Спросишь, зачем тогда нужны эти функции? А для того, чтобы очищать ресурсы во время работы приложения, для замены или просто перезагрузки их содержимого — как, например, мы явно вызывали деструкторы наших классов перед перезапуском игры.

Тем не менее, в качестве эксперимента автор решил написать функции удаления объектов и вот, что он получил. Как и следовало ожидать, процесс компиляции завершился успешно, — программа запустилась под дебагером. Кроме того, по команде автора она спокойно завершила свое выполнение. Однако, в следующий раз, когда yurembo снова запустил программу, угробил под огнем

вражеским своего робота, начал игру заново и попытался прикрыть ее… — дебагер запаниковал. И, даже выполняя проверку на сущес-

твование объекта (функции dbImageExist, dbObjectExist, etc)

перед их удалением, дебагер не успокоился. Тогда, углубившись в дебри листингов (как сишных, так и дизассемблерных), автор пришел к вышеописанному выводу.

Заключение

В аутсайдерах остался еще один модуль DirectX — это DirectPlay.

О мультиплеере мы, будем надеяться, подробно поговорим в следующей статье, где нашей целью будет разработать мультиплеерную баталию. z

097

 

 

 

 

hang

e

 

 

 

 

 

 

 

 

C

 

E

 

 

 

 

 

X

 

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

 

F

 

 

 

 

 

 

t

 

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

 

r

 

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

>>m

 

 

w Click

to

 

 

 

coding

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

 

.

 

 

 

 

 

.c

 

 

 

 

p

 

 

 

 

g

 

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

н

/ baiborodin@gmail.com /

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

Твердокаменный

AJAX

Защищаем веб-приложения, построенные на популярных AJAX-фреймворках

Год назад об AJAX говорили как о новой перспективной технологии, но сегодня он как-то выпал из поля зрения. Значит ли это, что AJAX не оправдал надежд и постепенно уходит в историю? Нет и еще раз нет. AJAX — это технология back-end, реализация которой перешла с прикладного уровня на уровень фреймворков.

Передовая линия обороны

Лежащие в основе огромного числа веб-проектов Dojo, GoogleWeb Toolkit, jQuery, Prototype, в свою очередь, являются дружественной к разработчику реализацией AJAX. А задумывался ли ты о потенциальных брешах в безопасности, прикручивая к своему проекту один из упомянутых фреймворков?

Если ты не хочешь отдать свой веб-проект на растерзание стае скрипткиддисов, то просто обязан знать об основной уязвимости AJAX-прило- жений. Эта уязвимость носит архитектурный характер. Другими словами, полноценного решения проблемы не существует и вряд ли когда-нибудь появится. Все, что ты можешь сделать — это минимизировать риск возможного взлома, предприняв ряд целенаправленных действий. Знакомься с мистером проблемой номер один — Hijacking!

Чтобы эффективно противодействовать этому виду атаки на AJAXприложения, неплохо было бы разобраться с тем, как эта ботва работает. Если говорить в двух словах, то в основе AJAX лежит обмен сообщениями между сервером и клиентом посредством JavaScriptсообщений. Hijacking нацелен на перехват таких сообщений (в которых можно найти много вкусностей). Традиционный обмен сообщениями между веб-клиентом и сервером лучше защищен

от подобных атак благодаря технологии SOP (Same Origin Policy).

Какой-либо защиты сообщений, формируемых с помощью JavaScript, пока не наблюдается. Кстати говоря, это должно быть головной болью разработчиков веб-браузеров, но они просто игнорируют проблему (что должно играть на руку читателям другой рубрики нашего журнала — «Взлом»). О том, что проблема не нова, свидетельствует следующий факт: достаточно давно существует еще одна реализация данной уязвимости, не имеющая никакого отношения к AJAX

— CSRF (Cross-site Request Foregery). Отметим, что применительно к JavaScript проблема становится еще более серьезной, так как злоумышленник теперь может не только изменять, но и читать передаваемые сообщения. Демонстрируя серьезность проблемы, достаточно будет сказать, что впервые она была обнаружена ни где-нибудь, а в самом Gmail.

Для защиты от атаки типа Hijacking запомни, прежде всего, простую, как трехдюймовая дискета, истину — если веб-приложение надежно защищено от XSS, это еще не говорит о его защите от

Hijacking. Чтобы сделать AJAX-приложение максимально непробиваемым, нужно, во-первых, сделать невозможным прямое выполнение JS-ответа. Во-вторых, нужно организовать отсылку в известном направлении всех кривых или просто подозрительных запросов. Начнем со второго пункта. Для того чтобы спалить всех

098

xàêåð 12 /120/ 08

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

>> codingw Click

 

BUY

 

 

to

 

 

 

 

m

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-x cha

 

 

 

 

Компоненты AJAX-enabled приложения

хитрозадых, достаточно будет использовать в шаблоне запроса параметр, со слепым подбором которого могут возникнуть траблы. К примеру, это может быть идентификатор сессии. Всякая ошибка в этом параметре будет расцениваться как сигнал о попытке взлома. Если по каким-то причинам у тебя нет возможности использовать параметры сессии, можно обойтись защитой на стороне сервера, настроив его на обработку только POST-запросов. Фишка в том, что задействованный при Hijacking тег <script> подтягивает внешние скрипты с помощью GET-запроса. Чтобы сделать невозможным для злонамеренного сайта выполнить ответ,

который включает в себя JavaScript, приложение клиента может воспользоваться тем, что ему разрешено изменять данные, которые оно получает перед тем, как выполнить ответ (в то время как злонамеренное приложение может лишь выполнить его, используя тэг <script>).

Когда сервер преобразовывает объект, тот должен иметь специальный префикс (и даже суффикс), который сделал бы невозможным выполнение JS-скрипта посредством тэга <script>. Приложение клиента может убрать дополнительные конструкции, перед тем как выполнить ответ сервера. Существует множество реализаций этого подхода. Мы выделим лишь два их них.

Архитектура AJAX-приложений

1.Сервер может сопровождать каждое сообщение следующей конструкцией:

while(1);

Если клиент не вырежет это выражение, то выполнение подобного сообщения JS-интерпретатором приведет к бесконечному циклу. Способ использовал Google, чтобы устранить уязвимость, обнаруженную Гроссманом. Клиент проводит поиск и вырезает дополнительную конструкцию:

var object;

var req = new XMLHttpRequest(); req.open("GET", "/object.json",true); req.onreadystatechange = function () {

if (req.readyState == 4) { var txt = req.responseText;

if (txt.substr(0,9) == "while(1);") { txt = txt.substring(10);

}

object = eval("(" + txt + ")"); req = null;

}

};

links

В Википедии есть учебник, посвященный основам AJAX — рекомендую для начинающих: ru.wikibooks.org/wiki/ AJAX.

Краткий обзор десяти наиболее серьезных проблем с безопасностью AJAX-приложе-

ний: www.netsecurity.org/article.

php?id=956&p=1.

• Статья AJAX Security Basics на SecurityFocus: www. securityfocus.com/ infocus/1868/1.

• Там же — интересная статья о взломе Web 2.0 приложений с помощью FireBug: www.securityfocus. com/infocus/1879/1.

xàêåð 12 /120/ 08

099

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

 

C

 

E

 

 

 

 

 

X

 

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

 

r

 

P

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

>>m

 

w Click

to

 

 

 

 

coding

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

-xcha

 

 

 

 

 

 

 

 

 

 

hang

e

 

 

 

 

 

 

 

 

C

 

E

 

 

 

 

X

 

 

 

 

 

 

-

 

 

 

 

 

d

 

 

F

 

 

 

 

 

 

t

 

 

D

 

 

 

 

 

 

 

 

i

 

 

 

 

 

 

 

 

 

 

r

P

 

 

 

 

 

 

NOW!

o

 

 

 

 

 

 

 

 

 

 

 

 

 

 

BUY

 

 

 

 

 

 

 

to

 

 

 

 

 

w Click

 

 

 

 

 

m

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

 

 

 

w

 

 

 

 

 

 

 

 

o

 

 

.

 

 

 

 

 

.c

 

 

 

p

 

 

 

 

g

 

 

 

 

 

 

df

 

 

n

e

 

 

 

 

 

 

-x cha

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Firebug — верный помощник в отладке AJAX-приложений

 

 

 

 

 

 

 

 

 

// Клиент может искать и вырезать комментарии

 

 

 

 

 

 

 

 

 

следующим образом:

 

 

 

 

 

 

 

 

 

var object;

 

 

 

 

 

 

 

 

 

var req = new XMLHttpRequest();

 

 

 

 

 

 

 

 

 

req.open("GET", "/object.json",true);

 

 

 

 

 

 

 

 

 

req.onreadystatechange = function () {

 

 

 

 

 

 

 

 

 

if (req.readyState == 4) {

 

 

 

 

 

 

 

 

 

var txt = req.responseText;

 

 

 

 

 

 

 

 

 

if (txt.substr(0,2) == "/*") {

 

 

 

 

 

 

 

 

 

txt = txt.substring(2, txt.length — 2);

 

 

 

 

 

 

 

 

}

 

 

 

 

 

 

 

 

 

object = eval("(" + txt + ")");

 

 

 

 

 

 

 

 

 

req = null;

 

 

 

 

 

 

 

 

 

Hijacking в картинках

 

 

 

 

 

 

}

 

 

 

 

 

 

 

 

};

 

 

 

 

 

 

 

 

 

 

 

 

 

req.send(null);

 

 

req.send(null);

 

 

 

 

 

 

 

 

 

 

 

 

2.Сервер может заключить JavaScript символами коммен-

 

Распределенные приложения

 

 

 

 

 

 

 

 

тария, которые впоследствии должны быть вырезаны (перед

или еще один кошмар на голову веб-кодера

 

 

тем, как JS-код отправится на выполнение). Следующий

С тенденцией, как говорится, не поспоришь. А тен-

 

 

JSON-объект окружен символами многострочного коммен-

денция сегодня такова, что девелоперы стройными

 

 

тария:

рядами двинулись в Сеть, особо не задумываясь над

dvd

 

 

 

 

 

 

вопросом «а нафига?». Трудно себе представить такое

На диске ты найдешь

/*

 

 

 

 

приложение, для которого бы не нашлось веб-аналога.

наиболее популяр-

 

[{"fname":"Nicholas", "lname":"Baiborodin",

 

Есть все — от блокнота до целых операционных систем

ные AJAX-фреймвор-

 

"phone":"322-233", "purchases":60000.00,

 

с полным набором прикладного софта и продвинутым

ки: Dojo, GWT, jQuery,

 

"email": "baiborodin@gmail.com" } ]

 

пользовательским интерфейсом. По своей природе такие

Prototype, Atlas.

*/

 

 

 

 

приложения имеют двухуровневую архитектуру — движок

 

 

 

 

 

 

 

 

крутим на сервере, а на стороне клиента через браузер

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

реализуем пользовательский интерфейс. Естественно,

 

 

 

 

 

 

 

 

 

 

 

Чтопочитать

 

 

разработчики в большинстве своем не пацаны сопливые,

 

 

 

 

 

а потому понимают, что для серверной части приложения

 

 

 

 

 

 

 

 

 

 

наиболее эффективными будут одни технологии и языки

 

 

 

 

 

 

 

 

 

 

 

 

 

 

программирования, а для клиентской — совсем другие.

info

Книгапосвященатехнологиивеб-программирова-

 

К тому же, одна серверная платформа может работать

Hijacking в переводе

нияAjax,стоящейнаступеньвышебазовыхDHTMLи

 

с совершенно разными клиентскими реализациями.

с английского на

JavaScript.СпомощьюAjaxможносоздаватьинтерак-

 

Что совершенно логично — будь то коктейль из HTML и

великий и могучий

тивныевеб-приложения,отличающиесябыстродейст­

 

JavaScript, или традиционное оконное приложение на

означает нападение,

 

виемивысокойпроизводительностью.Этакнигаотве-

 

C#, все они прекрасно найдут общий язык с серверной

ограбление и даже

 

титнавопрос,какасинхронныезапросыиспользуются

 

частью приложения посредством http-протокола и одного

угон самолета.

 

 

 

втехнологииAjax,ипоможетвыйтина

 

из XML-диалектов. Но это на бумаге все так гладко, а на

 

 

 

 

 

новыйуровеньвсозданиивеб-при-

 

практике… суди сам.

 

 

 

 

 

 

 

 

 

 

 

ложений.Особенностьюиздания

 

Допустим, серверное приложение написано на Java. В ответ

 

 

 

 

 

являетсяуникальныйспособподачи

 

на клиентский запрос оно возвращает один из элементов

 

 

 

 

 

материала,ярковыделяющийсерию

 

своего массива. Только вот в одних языках программиро-

 

 

 

 

 

«HeadFirst»издательстваO’Reillyв

 

вания индексация массивов начинается с нуля, а в других

 

 

 

 

 

рядумножествастандартныхкниг,

 

— с единицы со всеми вытекающими отсюда последстви­

 

 

 

 

 

 

 

 

 

Изучаем AJAX

посвященныхпрограммированию.

 

ями. Для того чтобы обезопасить себя от связанных с этим

 

 

 

 

 

100

xàêåð 12 /120/ 08

 

Соседние файлы в папке журнал хакер