cari
Rumahpembangunan bahagian belakangtutorial phpTidakkah anda tahu cara menggunakan alat pengekodan dan pemformatan php-cs-fixer ini?

php-cs-fixer - Alat pemformatan pengekodan PHP

php-cs-fixer ialah alat pemformatan kod Piawaian pemformatan ialah PSR-1, PSR-2 dan beberapa piawaian . Alat ini juga berasal dari keluarga yang sama seperti symfony, twig dan perpustakaan PHP lain yang sangat baik.

Pemasangan dan kemas kini

Memerlukan PHP 5.3.6 ke atas.

Anda boleh memuat turun terus pakej phar encapsulated: php-cs-fixer.phar; >

Atau muat turun melalui curl:

wget http://get.sensiolabs.org/php-cs-fixer.phar -O php-cs-fixer
Selepas muat turun selesai, berikan kebenaran boleh laku, dan kemudian pindah ke direktori bin:

curl http://get.sensiolabs.org/php-cs-fixer.phar -o php-cs-fixer
Itu sahaja Gunakan

perintah terus untuk memanggilnya di mana-mana sahaja.

sudo chmod a+x php-cs-fixer
sudo mv php-cs-fixer /usr/local/bin/php-cs-fixer
Anda juga boleh menggunakan Composer untuk memasang:

php-cs-fixer

Jika anda pengguna Mac, pengguna homebrew dan telah merakam homebrew/php, anda juga boleh terus:

composer global require fabpot/php-cs-fixer
Atau:

brew install php-cs-fixer
Jika anda perlu mengemas kini kemudian:

brew install homebrew/php/php-cs-fixer
Jika dipasang melalui homebrew:

php-cs-fixer self-update
Jika tiada fail boleh laku Letakkannya dalam direktori bin atau gunakan

bukannya

dalam Windows.
brew upgrade php-cs-fixer

Penggunaanphp php-cs-fixer.pharphp-cs-fixer juga sangat mudah digunakan Parameter arahan yang paling asas ialah

Apabila dilaksanakan secara langsung, sebanyak mungkin kod akan diformat mengikut piawaian lalai:

digunakan untuk memaparkan peraturan yang digunakan Format lalai ialah teks (fix). Pilihan

# 格式化目录 如果是当前目录的话可以省略目录
php-cs-fixer fix /path/to/dir
# 格式化文件
php-cs-fixer.phar fix /path/to/file

digunakan untuk mengawal tahap peraturan yang perlu digunakan: --verbosetxt

Secara lalai, semua pilihan PSR-2 dan beberapa pilihan tambahan (terutamanya berkaitan symfony ) dilaksanakan). Terdapat juga beberapa pilihan yang tergolong dalam "tahap sumbangan". Anda boleh menambahkannya secara terpilih melalui

Berbilang syarat --level hendaklah dipisahkan dengan koma:

php-cs-fixer fix /path/to/project --level=psr0
php-cs-fixer fix /path/to/project --level=psr1
php-cs-fixer fix /path/to/project --level=psr2
php-cs-fixer fix /path/to/project --level=symfony

juga boleh digunakan jika. perlu --fixers Gunakan senarai hitam untuk menetapkan pilihan yang dilumpuhkan. Jika kedua-dua --fixers dan

ditetapkan, yang pertama mempunyai keutamaan yang lebih tinggi.
php-cs-fixer fix /path/to/dir --fixers=linefeed,short_tag,indentation

Menggunakan arahan -name_of_fixer dan --fixers secara serentak boleh memaparkan ringkasan yang perlu diubah suai, tetapi sebenarnya tidak mengubahnya. -name_of_fixer

Anda juga boleh menyemak kandungan yang akan diubah suai melalui kaedah berikut, tetapi fail sebenarnya tidak akan ditukar:

--dry-run--diffKonfigurasi tersuai

pilihan tersedia Digunakan untuk menetapkan direktori dan fail terpilih untuk analisis dan pemformatan, tetapi pilihan ini hanya boleh menetapkan beberapa projek yang biasa diketahui, seperti symfony:
cat foo.php | php-cs-fixer fix --diff -

Pilihan sedia ada:

--config

# For the Symfony 2.3+ branch
php-cs-fixer fix /path/to/sf23 --config=sf23
konfigurasi lalai lalai

  • projek magento magento

  • projek symfony sf23

  • Lebih kerap , kami boleh menyesuaikan pilihan pemformatan dan mencari direktori dan fail melalui fail konfigurasi. Konfigurasi tersuai dicapai dengan menambahkan fail

    dalam direktori akar projek.

  • Tetapan itu sendiri ialah kod PHP, dan akhirnya mengembalikan contoh SymfonyCSConfigInterface. Anda boleh menetapkan pilihan pemformatan, tahap, fail dan direktori.

Berikut ialah contoh mudah: .php_cs

Jika anda ingin menyesuaikan sepenuhnya pilihan pemformatan, anda perlu mengosongkan tahap pemformatan dan menentukan semua pilihan yang diperlukan:

Anda juga boleh melumpuhkan pilihan tertentu dengan menambahkan
<?php $finder = Symfony\CS\Finder\DefaultFinder::create()
    ->exclude('somedir') // 忽略 somedir
    ->in(__DIR__) // 当前目录
;

return Symfony\CS\Config\Config::create()
    ->fixers(['strict_param', 'short_array_syntax']) // 添加两个选项
    ->finder($finder)
;
di hadapan pilihan Contohnya, contoh berikut tidak menggunakan PSR-0:

<?php $finder = Symfony\CS\Finder\DefaultFinder::create()
    ->in(__DIR__)
;

return Symfony\CS\Config\Config::create()
    ->level(Symfony\CS\FixerInterface::NONE_LEVEL)
    ->fixers(['trailing_spaces', 'encoding'])
    ->finder($finder)
;
Format di bawah keadaan lalai Tahap. pengoptimuman ialah symfony (yang paling ketat Anda boleh mengubah suai tahap ini:

-

Melalui gabungan pilihan tetapan ini, anda boleh menyesuaikan kesan yang anda inginkan dengan mudah.
<?php $finder = Symfony\CS\Finder\DefaultFinder::create()
    ->exclude('somedir')
    ->in(__DIR__)
;

return Symfony\CS\Config\Config::create()
    ->fixers(['-psr0'])
    ->finder($finder)
;

Anda juga boleh menentukan lokasi fail

melalui pilihan
<?php return Symfony\CS\Config\Config::create()
    ->level(Symfony\CS\FixerInterface::PSR2_LEVEL)
;
.

Mendayakan caching boleh mempercepatkan pelaksanaan berikutnya melalui kaedah berikut:

--config-file.php_csPemalam editor

Pemalam editor/IDE berikut boleh membantu. Anda memudahkan kerja pemformatan:

<?php return Symfony\CS\Config\Config::create()
    ->setUsingCache(true)
;

Atom

  • NetBeans

  • PhpStorm

  • Teks Luhur

  • Vim

  • Pilihan Pemformatan

psr0 [PSR-0]

    Piawaian laluan dan ruang nama untuk PSR-0



  • pengekodan [PSR-1 ]

  • Fail mesti dikodkan UTF-8 tanpa BOM;



  • short_tag [PSR-1]

  • Hanya dua Tag kod PHP,
  • dan

    , boleh digunakan
    <?php ?>= ?>

    pendakap [PSR-2]

  • Semua blok pernyataan mesti disertakan dalam pendakap kerinting, dan kedudukan serta lekukan adalah standard; Hanya terdapat satu ruang antara kelas, sifat, kata kunci antara muka dan nama;
  • bukannya

    ;


  • eof_ending [PSR-2]
  • Fail mesti berakhir dengan garisan Kosong ;

  • function_call_space [PSR-2]
    Apabila memanggil fungsi dan kaedah, tidak boleh ada ruang antara nama fungsi dan nama kaedah serta pengembangan parameter

  • function_declaration [PSR-2]
    Penggunaan ruang semasa mengisytiharkan fungsi perlu mematuhi PSR-2; 🎜>

  • lekukan [PSR-2]
  • Kod mesti menggunakan empat ruang untuk lekukan dan bukannya tab; 🎜>line_after_namespace [PSR-2]

    Mesti ada baris kosong selepas pengisytiharan ruang nama; 🎜>linefeed [PSR-2]

    Semua fail PHP hanya boleh menggunakan penghujung LF (Unix); -2 ]
  • Pemalar PHP benar, palsu dan nol mestilah huruf kecil




    kata kunci_huruf kecil [PSR-2]
  • Kata kunci PHP semuanya mestilah huruf kecil;




    method_argument_space [PSR-2]
  • Apabila kaedah diisytiharkan dan dipanggil , parameter Tidak boleh ada ruang sebelum koma, dan mesti ada ruang selepas koma




    multiple_use [PSR-2]
  • Setiap penggunaan hanya boleh mengisytiharkan satu elemen;




    kurungan [PSR-2]
  • Tidak boleh ada ruang pada kedua-dua belah kurungan; ;




    single_line_after_imports [PSR-2]
  • Setiap pernyataan penggunaan berada pada baris yang berasingan, dan mesti ada baris kosong selepas blok pernyataan penggunaan;




    trailing_spaces [PSR-2]
  • Padamkan ruang tambahan selepas baris bukan kosong; >




    keterlihatan [PSR-2]

  • Setiap sifat dan kaedah mesti menyatakan sama ada skopnya ialah
  • ,

    atau , dan
    mesti diletakkan Sebelum kata kunci skop, ?> mestilah selepas skop

  • array_element_no_space_before_comma [ symfony]
    Dalam pengisytiharan tatasusunan, Tidak boleh ada ruang sebelum koma;
    Dalam pengisytiharan tatasusunan, mesti ada ruang selepas koma;

  • blankline_after_open_tag [symfony]

    Tidak boleh menjadi kod pada baris yang sama pada teg permulaan PHP, dan mesti ada baris kosong di bawah; 🎜> Tidak boleh ada ruang tambahan di sebelah kiri dan kanan penyambung titik;
    Tidak boleh terdapat berbilang baris kosong pada kedua-dua hujung operator; ;


  • empty_return [symfony]publicprotected Jika pernyataan return tidak mengembalikan apa-apa, tulis sahaja return (tanpa return null); privateabstractfinalstatic

    extra_empty_lines [symfony]
  • Alih keluar baris kosong tambahan; >

    function_typehint_space [symfony]
    Betulkan ruang yang hilang antara parameter fungsi dan pembayang jenis Masalah; Perlu ada ruang antara

  • serta [symfony]

    dan laluan fail, tetapi bukan laluan fail yang dikelilingi oleh kurungan

  • join_function [symfony]
    Gunakan
    untuk menggantikan fungsi


  • list_commas [ symfony]

    Padamkan koma tambahan dalam penyataan


  • method_argument_default_value [symfony]=>

  • new_with_braces [symfony]
    Gunakan baharu untuk mencipta baharu Contoh hendaklah diikuti dengan tanda kurung; >

  • tiada_baris_kosong_selepas_pembukaan_kelas [symfony] Seharusnya tiada baris kosong selepas teg permulaan kelas;


    no_empty_lines_after_phpdocs [symfony]
  • Seharusnya tiada baris kosong di bawah elemen permulaan blok dokumentasi PHP




    object_operator [symfony]
  • () Seharusnya tiada ruang di kedua-dua hujungnya;

  • ruang_pengendali [symfony]
    Operator binari mempunyai sekurang-kurangnya satu ruang di kedua-dua hujungnya; >
    phpdoc_indent [symfony]

    phpdoc harus kekal indent;


  • phpdoc_inline_tag [symfony]

  • dan

    tidak sepatutnya muncul dalam phpdoc dalam


  • phpdoc_no_package [symfony]
  • dan tidak sepatutnya muncul dalam phpdoc;
    , @access,
    dan
    dsb. phpdoc Tag mesti dijajarkan secara menegak;

  • pengisytiharan jenis skalar phpdoc hendaklah menggunakan
  • bukannya

    , bukannya ,
    bukannya @return void atau @return null; 🎜>

  • phpdoc_separation [symfony]
  • sifat dengan komen yang sama dalam phpdoc harus disatukan, dan sifat yang berbeza harus dipisahkan oleh garis kosong;
    @package@subpackage
    phpdoc_short_description [symfony]

    Penerangan ringkas phpdoc hendaklah berakhir dengan
  • ,
  • atau

    ; >
    @param@throws@return phpdoc_to_comment [symfony]@var@type Semua blok dokumen mestilah elemen berstruktur; 🎜>

    phpdoc_trim [symfony]

  • Kecuali pada permulaan dan penghujung blok dokumentasi, phpdoc harus mempunyai kandungan pada awal dan akhir; >
  • phpdoc_type_to_var [symfony]
    int perlu diganti dengan integerboolbooleanfloatrealdouble;
    phpdoc_types [symfony]

    hendaklah betul dalam phpdoc Gunakan huruf besar dan kecil


  • phpdoc_var_without_name [symfony]

  • dan
  • ulasan tidak seharusnya mengandungi nama berubah; Penggunaan

    atau tidak boleh digunakan;
    .!?

    print_to_echo [symfony]

  • Jika boleh, gunakan
  • bukannya pernyataan

    ;


  • remove_leading_slash_use [symfony]
  • Alih keluar baris kosong sebelum ;


  • remove_lines_between_uses [symfony]

    Alih keluar baris kosong dalam blok pernyataan
    @type@var

  • kembali [symfony]
  • ; self_accessor [symfony]

    Gunakan Gantikan nama kelas; short_bool_cast [symfony]

  • Dua tanda seru tidak boleh digunakan sebelum jenis data;

  • @var@typesingle_array_no_trailing_comma] Harus ada baris kosong sebelum pengisytiharan ruang nama; bukannya petikan berganda;

  • ruang_selepas_koma bertitik [symfony]
    Betulkan ruang selepas koma bertitik i--i

  • ruang_sebelum_koma bertitik [symfony]

    Lumpuhkan hanya ruang satu baris dan pemisah Cara menulis nombor;
    echospaces_cast [symfony]print
    Perlu ada ruang antara pembolehubah dan pengubah suai; 🎜>standardkan_tidak_sama [symfony]

    Gunakan
  • dan bukannya
  • ;

    Normalkan ruang antara operator ternary;
    use

    trim_array_spaces [ symfony]
  • Tatasusunan perlu diformatkan serupa dengan fungsi/ parameter kaedah, tanpa garisan kosong di atas dan di bawah;

  • unary_operators_spaces [symfony]
    Unary operator dan operand perlu bersebelahan; 🎜>unneeded_control_parentheses [symfony]

    Alih keluar kurungan berlebihan dalam pernyataan struktur kawalan; > Padamkan pernyataan penggunaan yang tidak digunakan;


  • whitespacy_lines [symfony]

    Padamkan ruang tambahan dalam baris kosong;

  • Selain pilihan di atas, terdapat juga beberapa pilihan sumbangan pengguna, yang tidak akan diperkenalkan satu persatu di sini.
  • Setiap orang dan setiap pasukan mungkin mempunyai pendapat mereka sendiri sama ada gaya pengekodan harus disatukan dan piawaian yang perlu dilaksanakan. Ini hanyalah pengenalan kepada alat ini Mengenai cara memilihnya, terpulang kepada anda. Jika ia adalah projek sumber terbuka, anda juga boleh mencuba StyleCI. Pembelajaran yang disyorkan: "
    Tutorial Video PHP
    "

Atas ialah kandungan terperinci Tidakkah anda tahu cara menggunakan alat pengekodan dan pemformatan php-cs-fixer ini?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:segmentfault. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
Apakah kelebihan menggunakan pangkalan data untuk menyimpan sesi?Apakah kelebihan menggunakan pangkalan data untuk menyimpan sesi?Apr 24, 2025 am 12:16 AM

Kelebihan utama menggunakan sesi penyimpanan pangkalan data termasuk kegigihan, skalabilitas, dan keselamatan. 1. Kegigihan: Walaupun pelayan dimulakan semula, data sesi tidak dapat berubah. 2. Skalabiliti: Berkenaan dengan sistem yang diedarkan, memastikan data sesi disegerakkan di antara pelbagai pelayan. 3. Keselamatan: Pangkalan data menyediakan storan yang disulitkan untuk melindungi maklumat sensitif.

Bagaimana anda melaksanakan pengendalian sesi tersuai di PHP?Bagaimana anda melaksanakan pengendalian sesi tersuai di PHP?Apr 24, 2025 am 12:16 AM

Melaksanakan pemprosesan sesi tersuai dalam PHP boleh dilakukan dengan melaksanakan antara muka sessionHandlerInterface. Langkah -langkah khusus termasuk: 1) mewujudkan kelas yang melaksanakan sessionHandlerInterface, seperti CustomSessionHandler; 2) kaedah penulisan semula dalam antara muka (seperti terbuka, rapat, membaca, menulis, memusnahkan, gc) untuk menentukan kitaran hayat dan kaedah penyimpanan data sesi; 3) Daftar pemproses sesi tersuai dalam skrip PHP dan mulakan sesi. Ini membolehkan data disimpan dalam media seperti MySQL dan REDIS untuk meningkatkan prestasi, keselamatan dan skalabiliti.

Apakah ID Sesi?Apakah ID Sesi?Apr 24, 2025 am 12:13 AM

SesionID adalah mekanisme yang digunakan dalam aplikasi web untuk mengesan status sesi pengguna. 1. Ia adalah rentetan yang dijana secara rawak yang digunakan untuk mengekalkan maklumat identiti pengguna semasa pelbagai interaksi antara pengguna dan pelayan. 2. Pelayan menjana dan menghantarnya kepada klien melalui kuki atau parameter URL untuk membantu mengenal pasti dan mengaitkan permintaan ini dalam pelbagai permintaan pengguna. 3. Generasi biasanya menggunakan algoritma rawak untuk memastikan keunikan dan ketidakpastian. 4. Dalam pembangunan sebenar, pangkalan data dalam memori seperti REDIS boleh digunakan untuk menyimpan data sesi untuk meningkatkan prestasi dan keselamatan.

Bagaimanakah anda mengendalikan sesi dalam persekitaran tanpa kerakyatan (mis., API)?Bagaimanakah anda mengendalikan sesi dalam persekitaran tanpa kerakyatan (mis., API)?Apr 24, 2025 am 12:12 AM

Menguruskan sesi dalam persekitaran tanpa kerakyatan seperti API boleh dicapai dengan menggunakan JWT atau cookies. 1. JWT sesuai untuk ketiadaan dan skalabilitas, tetapi ia adalah saiz yang besar ketika datang ke data besar. 2.Cookies lebih tradisional dan mudah dilaksanakan, tetapi mereka perlu dikonfigurasikan dengan berhati -hati untuk memastikan keselamatan.

Bagaimanakah anda dapat melindungi daripada serangan skrip lintas tapak (XSS) yang berkaitan dengan sesi?Bagaimanakah anda dapat melindungi daripada serangan skrip lintas tapak (XSS) yang berkaitan dengan sesi?Apr 23, 2025 am 12:16 AM

Untuk melindungi permohonan dari serangan XSS yang berkaitan dengan sesi, langkah-langkah berikut diperlukan: 1. Tetapkan bendera httponly dan selamat untuk melindungi kuki sesi. 2. Kod eksport untuk semua input pengguna. 3. Melaksanakan Dasar Keselamatan Kandungan (CSP) untuk mengehadkan sumber skrip. Melalui dasar-dasar ini, serangan XSS yang berkaitan dengan sesi dapat dilindungi dengan berkesan dan data pengguna dapat dipastikan.

Bagaimana anda boleh mengoptimumkan prestasi sesi PHP?Bagaimana anda boleh mengoptimumkan prestasi sesi PHP?Apr 23, 2025 am 12:13 AM

Kaedah untuk mengoptimumkan prestasi sesi PHP termasuk: 1. Mula sesi kelewatan, 2. Gunakan pangkalan data untuk menyimpan sesi, 3. Data sesi kompres, 4. Mengurus kitaran hayat sesi, dan 5. Melaksanakan perkongsian sesi. Strategi ini dapat meningkatkan kecekapan aplikasi dalam persekitaran konkurensi yang tinggi.

Apakah tetapan konfigurasi sesi.gc_maxlifetime?Apakah tetapan konfigurasi sesi.gc_maxlifetime?Apr 23, 2025 am 12:10 AM

Thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata, setInseconds.1) it'sconfiguredinphp.iniorviaini_set (). 2) abalanceisneededtoavoidperformanceissuesandunexpectedlogouts.3) php'sgarbageCollectionisprobabilistic, influedbygc_probabi

Bagaimana anda mengkonfigurasi nama sesi dalam php?Bagaimana anda mengkonfigurasi nama sesi dalam php?Apr 23, 2025 am 12:08 AM

Dalam PHP, anda boleh menggunakan fungsi session_name () untuk mengkonfigurasi nama sesi. Langkah -langkah tertentu adalah seperti berikut: 1. Gunakan fungsi session_name () untuk menetapkan nama sesi, seperti session_name ("my_session"). 2. Selepas menetapkan nama sesi, hubungi session_start () untuk memulakan sesi. Mengkonfigurasi nama sesi boleh mengelakkan konflik data sesi antara pelbagai aplikasi dan meningkatkan keselamatan, tetapi memberi perhatian kepada keunikan, keselamatan, panjang dan penetapan masa sesi.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),