suchen

thinkphp笔记

M 项目目录/应用目录/Lib/Model

 V 项目目录/应用目录/Tpl

 C 项目目录/应用目录/Lib/Action

 

1.PATHINFO 模式    http://域名/项目名/入口文件/模块名/方法名/键1/值1/键2/值2

2.普通模式    http://域名/项目名/入口文件?m=模块名&a=方法名&键1=值1&键2=值2

3.REWRITE模块    http://域名/项目名/模块名/方法名/键1/值1/键2/值2

4.兼容模式    http://域名/项目名/入口文件?s=模块名/方法名/键1/值1/键2/值2

 

// 本类由系统自动生成,仅供测试用途
class IndexAction extends Action {
    public function index(){
        echo "hello world";
}
    public function add(){
        echo "你好,吴昊
";

        echo '你好'.$_GET['name'].'你的年龄是'.$_GET['age'];
    }
}

http://localhost/test/index.php/Index/add?name=wuhao

http://localhost/test/index.php/Index/add/name/wuhao

http://localhost/test/index.php/Index/add/name/wuhao/age/18

 

'URL_PATHINFO_DEPR'=>'-',    //修改URL的分隔符

'TMPL_L_DELIM'=>'

'TMPL_R_DELIM'=>'}>', //修改右定界符

http://localhost/test/index.php/Index-add-name-wuhao-age-23 

 

http://localhost/test/index.php/Index/index

http://localhost/test/index.php/Index/add

public function add(){

      /*echo "你好,吴昊
";

      echo '你好'.$_GET['name'].'你的年龄是'.$_GET['age'];*/

      $name='吴昊';

      $this->assign('myname',$name);

      //$this->myname='abc';

      $this->display();

 }


一些动态的数据可以通过assign()方法分配给模板显示

访问了add方法。

你好!{$myname}

D:\wamp\www\test\App\Tpl\Index

 

需要在方法中通过new Model(表名)的形式操作数据库

  $m=new Model('User');

  $arr=$m->select(); 

 'DB_TYPE'=>'mysql',   //设置数据库类型

 'DB_HOST'=>'localhost',//设置主机

 'DB_NAME'=>'thinkphp',//设置数据库名

 'DB_USER'=>'root',    //设置用户名

 'DB_PWD'=>'',        //设置密码

 'DB_PORT'=>'3306',   //设置端口号

 'DB_PREFIX'=>'tp_',  //设置表前缀

 'DB_DSN'=>'mysql://root:@localhost:3306/thinkphp',//使用DSN方式配置数据库信息 ,优先级比传统方式高

 $user=new Model('User');

    $arr=$user->select();

    var_dump($arr);

    $this->display();

 

'SHOW_PAGE_TRACE'=>true,//开启页面Trace

还有一种简单实用模型的方式

 M() 等效为 new Model();

 $m=M('User');

 $arr=$m->select();

 

使用模型的实例可以对数据进行操作,操作的工作一般就是对数据库进行 增删改查 CURD

 增 -C Create $m->add()

 删 -D Delete $m->delete()

 改 -U Update $m->save()

 查 -R Read   $m->select()

 

a、模板可以遍历数组

 

   {$vo.id}----{$vo.username}-----{$vo.sex}

 

 b、我们可以开启调试功能中的page_trace

  1.开启调试功能

   define('APP_DEBUG',true);

  2.我们需要设置配置文件,开启页面trace

   'SHOW_PAGE_TRACE'=>true,//开启页面Trace

 

读取数据

 对数据的读取 Read

 $m=new Model('User');

 $m=M('User');

 select:$m->select();    //获取所有数据,以数组形式返回

 find:$m->find($id);    //获取单条数据

 getField(字段名)    //获取一个具体的字段值

 $arr=$m->where('id=2')->getField('username');

创建数据   

 对数据的添加 Create

 $m=new Model('User');

 $m=M('User');

 $m->字段名=值

 $m->add();    返回值是新增的id号

删除数据   

 $m=M('User');

 $m->delete(2);               //删除id为2的数据

 $m->where('id=2')->delete();    返回值是受影响行数

更新数据

 $m=M('User');

 $data['id']=1;

 $data['username']='ztz2';

 $m->save($data);      返回值是受影响行数

 

 

CURD演示:

==================================================================================================================================================================================================

查询方式:

一、普通查询方式

 a、字符串

  $arr=$m->where("sex=0 and username='gege'")->find();

 b、数组

  $data['sex']=0;

  $data['username']='gege';

  $arr=$m->where($data)->find();

  注意:这种方式默认是and的关系,如果使用or关系,需要添加数组值:$data['_logic']='or';

二、表达式查询方式

  $data['id']=array('lt',6);    $arr=$m->where($data)->select();

  EQ 等于,NEQ不等于, GT 大于,EGT大于等于, LT 小于,ELT小于等于,LIKE 模糊查询

   $data['username']=array('like','%ge');    $arr=$m->where($data)->select();

  NOTLIKE

   $data['username']=array('notlike','%ge%');    $arr=$m->where($data)->select();

   注意:如果一个字段要匹配多个通配符

   $data['username']=array('like',array('%ge%','%2%','%五%'),'and');    //如果没有第三个值,默认关系是or关系

  BETWEEN

   $data['id']=array('between',array(5,7));    $arr=$m->where($data)->select();

   //SELECT * FROM `tp_user` WHERE ( (`id` BETWEEN 5 AND 7 ) )

   $data['id']=array('not between',array(5,7));    $arr=$m->where($data)->select();

  IN

   $data['id']=array('in',array(4,6,7));    $arr=$m->where($data)->select();

   //SELECT * FROM `tp_user` WHERE ( `id` IN (4,6,7) )

   $data['id']=array('not in',array(4,6,7));    $arr=$m->where($data)->select();

   //SELECT * FROM `tp_user` WHERE ( `id` NOT IN (4,6,7) )

三、区间查询

  $data['id']=array(array('gt',4),array('lt',10));    //默认关系是 and 的关系

  //SELECT * FROM `tp_user` WHERE ( (`id` > 4) AND (`id`

  $data['id']=array(array('gt',4),array('lt',10),'or')     //关系就是or的关系

  $data['name']=array(array('like','%2%'),array('like','%五%'),'gege','or');

四、统计查询

  count  //获取个数;max   //获取最大数;min   //获取最小数;avg   //获取平均数;sum   //获取总和

五、SQL直接查询

 a、query 主要是处理读取数据的:成功返回数据的结果集,失败返回boolean false

  $m=M();

  $result=$m->query("select *  from t_user where id >50");

  var_dump($result);

 b、execute 用于更新个写入操作:成功返回影响行数,失败返回boolean false

  $m=M();

  $result=$m->execute("insert into t_user(`username`) values('ztz3')");

  var_dump($result);

 

'DB_LIKE_FIELDS'=>'title|content'     //查询语句中条件自动变为模糊查询%%

查询方式演示:

==================================================================================================================================================================================================

常用连贯操作

 1.where     帮助我们设置查询条件 

 2.order     对结果进行排序 

  $arr=$m->order('id desc')->select();    $arr=$m->order(array('id'=>'desc','sex'=>'asc'))->select();

 3.limit    限制结果 

  limit(2,5)     limit('2,5')     limit(10)    //limit(0,10)

 4.field     设置查询字段 

  field('username as name,id')    field(array('username'=>'name','id')

  field('id',true)     //获取除了id以外的所有字段

 5.table

 6.group

 7.having

二、补充  

   alias 用于给当前数据表定义别名 字符串

   page 用于查询分页(内部会转换成limit) 字符串和数字

   join* 用于对查询的join支持 字符串和数组

   union* 用于对查询的union支持 字符串、数组和对象

   distinct 用于查询的distinct支持 布尔值

   lock 用于数据库的锁机制 布尔值

   cache 用于查询缓存 支持多个参数(以后在缓存部分再详细描述)

   relation 用于关联查询(需要关联模型扩展支持) 字符串

   validate 用于数据自动验证 数组

   auto 用于数据自动完成 数组

   filter 用于数据过滤 字符串

   scope* 用于命名范围 字符串、数组 

==================================================================================================================================================================================================

视图:

一、模板的使用        

 a、规则

  模板文件夹下[TPL]/[分组文件夹/][模板主题文件夹/]和模块名同名的文件夹[Index]/和方法名同名的文件[index].html(.tpl)

  更换模板文件的后缀名(修改配置文件)

  'TMPL_TEMPLATE_SUFFIX'=>'.html',    //更改模板文件后缀名

 b、修改模板文件目录层次

  'TMPL_FILE_DEPR'=>'_',    //修改模板文件目录层次

 c、模板主题

  'DEFAULT_THEME'=>'your',    //设置默认模板主题

  需要在TPL下面新建一个your文件夹作为模板主题文件夹

  如何动态修改模板主题?

  1、在后台准备一个功能,修改config.php文件中的默认模板项

  2、通过url传递 t=主题 参数可以修改不同的模板

   'DEFAULT_THEME'=>'your',//设置默认模板主题

   'TMPL_DETECT_THEME'=>true,//自动侦测模板主题

   'THEME_LIST'=>'your,my',//支持的模板主题列表

http://localhost/test/index.php/Index/index/t/my    http://localhost/test/index.php/Index/index/t/you

二、输出模板内容   

 a、display

  1.display中没有参数:$this->display();

  2.可以带参数

   $this->display(本模块文件夹下的其他模板文件);

   $this->display('index2');

   $this->display(其他文件夹下的模板文件);

   $this->display('Public:error');    //注意,仅仅需要在Tpl下有Public文件夹以及其中的error.html即可,不需要一定有Public模块

   $this->display(其他主题下的 文件夹下的 模板文件);    //需要开启主题支持

   $this->display('my:Index:index');

   $this->display(一个URL路径);

   $this->display('./Public/error.html');

   $this->display('./Public/error.html','utf-8','text/xml');

   $this->show($content);

  3.fetch方法

   获得模板文件中的内容,以字符串形式返回:$content=$this->fetch('Public:error');

  4.show方法

   不需要模板文件,可以直接输出模板内容

    $content=$this->fetch('Public:error');

    dump($content);

    $content=str_replace('h1','i',$content);

    $this->show($content);

三、模板中的赋值      

  //$this->assign('name','赵桐正');

  $this->name='赵桐正2';     $this->display();

四、模板替换      

__PUBLIC__:会被替换成当前网站的公共目录 通常是 /Public/

__ROOT__: 会替换成当前网站的地址(不含域名)

__APP__: 会替换成当前项目的URL地址 (不含域名)

__GROUP__:会替换成当前分组的URL地址 (不含域名)

__URL__: 会替换成当前模块的URL地址(不含域名)

__ACTION__:会替换成当前操作的URL地址 (不含域名)

__SELF__: 会替换成当前的页面URL

  更换模板变量规则,修改配置项

  'TMPL_PARSE_STRING'=>array(           //添加自己的模板变量规则

  '__CSS__'=>__ROOT__.'/Public/Css',

  '__JS__'=>__ROOT__.'/Public/Js',

 ),

 

登录框实例:

引入扩展类,把ThinkPHP3.1.2_Extend里面的文件放在D:\wamp\www\test\ThinkPHP\Extend文件夹下。

对应的js和css:

D:\wamp\www\test\Public\Css    ·D:\wamp\www\test\Public\Js

==================================================================================================================================================================================================

模板中的变量:

一、变量输出        

  1.标量输出

  2.数组输出

    {$name[1]}    {$name['k2']}    {$name.k1}

  3.对象输出

    {$name:k}    {$name->k}

二、系统变量

用法 含义 例子
$Think.server 获取$_SERVER {$Think.server.php_self}
$Think.get 获取$_GET {$Think.get.id}
$Think.post 获取$_POST {$Think.post.name}
$Think.request 获取$_REQUEST {$Think.request.user_id}
$Think.cookie 获取$_COOKIE {$Think.cookie.username}
$Think.session 获取$_SESSION {$Think.session.user_id}
$Think.config 获取系统配置参数 {$Think.config.app_status}
$Think.lang 获取系统语言变量 {$Think.lang.user_type}
$Think.const 获取系统常量 {$Think.const.app_name}或{$Think.APP_NAME}
$Think.env 获取环境变量 {$Think.env.HOSTNAME}
$Think.version 获取框架版本号 {$Think.version}
$Think.now 获取当前时间 {$Think.now}
$Think.template 获取当前模板 {$Think.template}
$Think.ldelim 获取模板左界定符 {$Think.ldelim}
$Think.rdelim 获取模板右界定符 {$Think.rdelim}

三、使用函数

  {$name|strtoupper} 生成的编译后文件是:

  {$name|date='Y m d H:i:s',###}

四、默认值

  {$name|default='这里是默认值'}

五、运算符

  + - * / % ++ --        {$name++}

 

模板中的基本语法:

一、导入CSS和JS文件      

 1、

     

 2.import

      //导入Public文件夹下面的Js目录中的test.js文件,import标签可以省略type属性,默认就是js的

 

      //可以更改默认文件夹 设置basepath属性

 3.load

      //方法可以自动检测导入的文件类型

二、分支结构

 

       未成年

   

       青春年少

   

       成年

     

  >  gt     = egt      != neq     === heq     !== nheq 

 

       一个和尚挑水吃

       两个和尚台水吃

       三个和尚没水吃

        这里是默认值

 

三、循环结构

 1.for

 

       

           

       

 

{$j} abc

 2.volist

 

   {$v.username}

 

 3.foreach

  $user=M('User1');

  $arr=$user->select();

  $this->assign('list',$arr);

  $this->display();

 

 

     

           

{$v.id}

           

{$v.username}

           

{$v.sex}

           

{$v.password}

     

 

四、特殊标签

 1、比较标签

   eq或者 equal 等于   neq 或者notequal 不等于      gt 大于     egt 大于等于     lt 小于     elt 小于等于     heq 恒等于   nheq 不恒等于  

 2.范围标签

  in      

    在这些数字里面不在这些数字的范围内

    在这些数字里面不在这些数字的范围内

  between

    {$n}在1-10之间{$n}不在1到10之间

 3.present:标签来判断模板变量是否已经赋值,

  m有赋值m没有赋值

 4.Empty:empty标签判断模板变量是否为空,

  n为空赋值n有值

 5.Defined: 判断常量是否已经定义

 6.Define:在模板中定义常量

 7.Assing: 模板中变量赋值

五、其他标签使用

 1、在模板中直接使用PHP代码

  echo "我是赵桐正"

 2、建议更改左右定界符

  在配置文件中改变

   'TMPL_L_DELIM'=>'

   'TMPL_R_DELIM'=>'}>', //修改右定界符

 

模板的使用技巧:

一、模板包含

 

 

 

 

 

 

 

  在模板中变量用[变量]接受:

二、模板渲染

 1、自动开启模板渲染 设置配置文件

   'LAYOUT_ON'=>true,    //开启模板渲染

   准备一个模板渲染页面,在页面中使用{__CONTENT__}接受具体模板页面的内容

   如果在某一个具体模板中不希望使用渲染模板,可以在页首添加{__NOCONTENT__}

 2、不开启自动模板渲染可以在每一个具体页面的页首添加:

 3.使用技巧:在渲染模板文件中也可以使用其他模板文件的内容

 

     

           

这里是渲染页面!!!

           {__CONTENT__}

     

 

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Wie funktioniert der Php -Typ -Hinweis, einschließlich Skalartypen, Rückgabetypen, Gewerkschaftstypen und nullbaren Typen?Wie funktioniert der Php -Typ -Hinweis, einschließlich Skalartypen, Rückgabetypen, Gewerkschaftstypen und nullbaren Typen?Apr 17, 2025 am 12:25 AM

PHP -Typ -Eingabeaufforderungen zur Verbesserung der Codequalität und der Lesbarkeit. 1) Tipps zum Skalartyp: Da Php7.0 in den Funktionsparametern wie int, float usw. angegeben werden dürfen. 3) Eingabeaufforderung für Gewerkschaftstyp: Da Php8.0 in Funktionsparametern oder Rückgabetypen angegeben werden dürfen. 4) Nullierstyp Eingabeaufforderung: Ermöglicht die Einbeziehung von Nullwerten und Handlungsfunktionen, die Nullwerte zurückgeben können.

Wie handelt es sich bei PHP -Objektklonen (Klonschlüsselwort) und der __clone Magic -Methode?Wie handelt es sich bei PHP -Objektklonen (Klonschlüsselwort) und der __clone Magic -Methode?Apr 17, 2025 am 12:24 AM

Verwenden Sie in PHP das Klonschlüsselwort, um eine Kopie des Objekts zu erstellen und das Klonierungsverhalten über die \ _ \ _ Clone Magic -Methode anzupassen. 1. Verwenden Sie das Klonschlüsselwort, um eine flache Kopie zu erstellen und die Eigenschaften des Objekts, nicht die Eigenschaften des Objekts zu klonen. 2. Die \ _ \ _ Klonmethode kann verschachtelte Objekte tief kopieren, um flache Kopierprobleme zu vermeiden. 3. achten Sie darauf, dass kreisförmige Referenzen und Leistungsprobleme beim Klonen vermieden werden, und optimieren Sie die Klonierungsvorgänge, um die Effizienz zu verbessern.

PHP vs. Python: Anwendungsfälle und AnwendungenPHP vs. Python: Anwendungsfälle und AnwendungenApr 17, 2025 am 12:23 AM

PHP eignet sich für Webentwicklungs- und Content -Management -Systeme, und Python eignet sich für Datenwissenschafts-, maschinelles Lernen- und Automatisierungsskripte. 1.PHP hat eine gute Leistung beim Erstellen von schnellen und skalierbaren Websites und Anwendungen und wird üblicherweise in CMS wie WordPress verwendet. 2. Python hat sich in den Bereichen Datenwissenschaft und maschinelles Lernen mit reichen Bibliotheken wie Numpy und TensorFlow übertrifft.

Beschreiben Sie verschiedene HTTP-Caching-Header (z. B. Cache-Control, ETAG, Last-modifiziert).Beschreiben Sie verschiedene HTTP-Caching-Header (z. B. Cache-Control, ETAG, Last-modifiziert).Apr 17, 2025 am 12:22 AM

Zu den wichtigsten Spielern in HTTP-Cache-Headern gehören Cache-Control, ETAG und Last-modifiziert. 1.Cache-Control wird verwendet, um die Richtlinien zu kontrollieren. Beispiel: Cache-Control: max-ay = 3600, öffentlich. 2. ETAG überprüft Ressourcenänderungen durch eindeutige Identifikatoren, Beispiel: ETAG: "686897696A7C876B7E". 3. Last-modifiziert gibt die letzte Änderungszeit der Ressource an, Beispiel: Last-Modified: Mi, 21okt201507: 28: 00GMT.

Erklären Sie sicheres Kennwort -Hashing in PHP (z. B. password_hash, password_verify). Warum nicht MD5 oder SHA1 verwenden?Erklären Sie sicheres Kennwort -Hashing in PHP (z. B. password_hash, password_verify). Warum nicht MD5 oder SHA1 verwenden?Apr 17, 2025 am 12:06 AM

In PHP sollten die Funktionen für Passwort_Hash und passwart_verify verwendet werden, um sicheres Passwort -Hashing zu implementieren, und MD5 oder SHA1 sollte nicht verwendet werden. 1) Passwort_hash generiert einen Hash, der Salzwerte enthält, um die Sicherheit zu verbessern. 2) Passwort_Verify prüfen Sie das Passwort und sicherstellen Sie die Sicherheit, indem Sie die Hash -Werte vergleichen. 3) MD5 und SHA1 sind anfällig und fehlen Salzwerte und sind nicht für die Sicherheit der modernen Passwort geeignet.

PHP: Eine Einführung in die serverseitige SkriptsprachePHP: Eine Einführung in die serverseitige SkriptspracheApr 16, 2025 am 12:18 AM

PHP ist eine serverseitige Skriptsprache, die für dynamische Webentwicklung und serverseitige Anwendungen verwendet wird. 1.PHP ist eine interpretierte Sprache, die keine Zusammenstellung erfordert und für die schnelle Entwicklung geeignet ist. 2. PHP -Code ist in HTML eingebettet, wodurch es einfach ist, Webseiten zu entwickeln. 3. PHP verarbeitet die serverseitige Logik, generiert die HTML-Ausgabe und unterstützt Benutzerinteraktion und Datenverarbeitung. 4. PHP kann mit der Datenbank interagieren, die Einreichung von Prozessformularen und serverseitige Aufgaben ausführen.

PHP und das Web: Erforschen der langfristigen AuswirkungenPHP und das Web: Erforschen der langfristigen AuswirkungenApr 16, 2025 am 12:17 AM

PHP hat das Netzwerk in den letzten Jahrzehnten geprägt und wird weiterhin eine wichtige Rolle bei der Webentwicklung spielen. 1) PHP stammt aus dem Jahr 1994 und ist aufgrund seiner Benutzerfreundlichkeit und der nahtlosen Integration in MySQL die erste Wahl für Entwickler. 2) Zu den Kernfunktionen gehört das Generieren dynamischer Inhalte und die Integration in die Datenbank, sodass die Website in Echtzeit aktualisiert und auf personalisierte Weise angezeigt wird. 3) Die breite Anwendung und das Ökosystem von PHP hat seine langfristigen Auswirkungen angetrieben, steht jedoch auch mit Versionsaktualisierungen und Sicherheitsherausforderungen gegenüber. 4) Leistungsverbesserungen in den letzten Jahren, wie die Veröffentlichung von PHP7, ermöglichen es ihm, mit modernen Sprachen zu konkurrieren. 5) In Zukunft muss PHP sich mit neuen Herausforderungen wie Containerisierung und Microservices befassen, aber seine Flexibilität und die aktive Community machen es anpassungsfähig.

Warum PHP verwenden? Vorteile und Vorteile erläutertWarum PHP verwenden? Vorteile und Vorteile erläutertApr 16, 2025 am 12:16 AM

Zu den Kernvorteilen von PHP gehören einfacher Lernen, starke Unterstützung für Webentwicklung, reiche Bibliotheken und Rahmenbedingungen, hohe Leistung und Skalierbarkeit, plattformübergreifende Kompatibilität und Kosteneffizienz. 1) leicht zu erlernen und zu bedienen, geeignet für Anfänger; 2) gute Integration in Webserver und unterstützt mehrere Datenbanken. 3) leistungsstarke Frameworks wie Laravel; 4) hohe Leistung kann durch Optimierung erzielt werden; 5) mehrere Betriebssysteme unterstützen; 6) Open Source, um die Entwicklungskosten zu senken.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools