Çevrimiçi mağazanızda kripto ödemelerini kabul etmeye nasıl başlayabilirsiniz?

accept crypto bitcoin usdt on website

Mitilena Pay ile web sitenizde 5 dakika içinde kripto para birimini kabul edinprocessing company for accepting cryptocurrencies on the site

  1. Sistemimize kayıt olun, kayıt anında gerçekleşir, herhangi bir onay gerekmemektedir.
  2. Mağazanızı API veya WordPress Woocommerce eklentisi aracılığıyla bağlayın.
  3. Mallarınız için kripto para birimiyle ödeme kabul etmeye başlayın!
  4. Herhangi bir kısıtlama olmaksızın herhangi bir cüzdanınıza kripto para birimini çekin.  
Kripto para birimlerini kabul etmeye yönelik özelliklerimiz:
  • Hızlı kayıt
  • Haftanın yedi günü, istediğiniz zaman 5 dakikada bağlanın
  • Üç blok zincirde USDT desteği (ERC20 Ethereum, TRC20 Tron, BEP20 Binance Smart Chain)
  • WooCommerce için hazır eklenti (WordPress)
  • İlk 90 günlük komisyon %0, ardından %0,8’dir
Şu anda aşağıdaki kripto para birimlerini destekliyoruz: USDT, VMT, APFC. Talep üzerine ihtiyacınız olan kripto para birimini ekleyebiliriz.

Biraz daha detaylı:

  1. Bir kullanıcı alışveriş sepetinde kripto para birimleri ile ödeme yapmayı seçtiğinde sistemimizin kripto para birimleri ile ödeme yapma sayfasına yönlendirilir.
  2. Fiyat oluşum süreci şu şekildedir: tüm siparişin maliyeti USD’ye, ardından kripto para birimine dönüştürülür. Oran, ülkenizin resmi Merkez Bankası tarafından komisyonsuz olarak hesaplanır.
  3. USDT kripto para birimindeki ödemeler çok hızlıdır, yaklaşık 3 saniye. Ödeme yapıldıktan sonra kullanıcının ödeme sayfası ona ödemenin başarılı olduğunu bildirir. Bir çevrimiçi mağazanın sahibi olarak ödemenin başarılı olduğunu bildiren bir e-posta alırsınız.
  4. Sistemimizden kripto para birimini istediğiniz zaman başka bir adrese çekebilirsiniz. Cüzdanımızda bulunan soğuk cüzdanınıza çekmenizi tavsiye ederiz.

F.A.Q.

Ödemeler nasıl takip ediliyor?

Ödemeler, her ödemeye, fiyatı doğrudan etkilemeyen, ancak ödemeyi tanımlamanıza olanak tanıyan ve daha da önemlisi, daha sonra tüm ödemeleri 1 cüzdanda toplama konusunda tasarruf etmenize olanak tanıyan benzersiz numaralar eklenerek benzersiz sistemimize göre takip edilir.

Ödeme takip sisteminizle nasıl tasarruf yaparım?

Genellikle internette kripto para birimi aracılığıyla ödeme yaparken müşteri her zaman ödeme için yeni bir adres alır. Her faturanın yeni bir ödeme adresi vardır. Yani günlük 1000 siparişiniz varsa sizin için 1000 adres oluşturulacak ve 1000 adrese ödeme alınacaktır. Daha sonra tüm ödemeleri tek cüzdanda toplamak için 1000 kat komisyon ödemeniz gerekecek, tek işlemde birçok adresi girseniz bile çok pahalı olacaktır. Kısaca 1000 işlem = 1000 ücret (örneğin işlem başına bir dolar). Bu, bu ödeme yönteminin maliyetini büyük ölçüde artırır. Bizde, benzersiz teknolojimiz ve dolayısıyla doların milyonda biri başına düşen tutarların farklı olması nedeniyle, 1000 ödemeyi tek bir adrese topluyoruz ve ancak ondan sonra değiştiriyoruz. Komisyonlarda 1000 kat tasarruf elde ediliyor.

Başka ne gibi faydalar var?

USDT’de en hızlı sisteme sahibiz, ödeme ilk birkaç blok için birkaç saniye sürer ve durum Başarılı’dır. Stablecoin kullanımı nedeniyle döviz kurunda daha az dalgalanma olur, bu da kripto para birimini minimum riskle, ancak ihtiyacınız olmasa bile çok iyi bir anonimlikle düzenli bir ödeme aracı olarak kullanmanıza olanak tanır.

O halde toplanan kripto para birimi nasıl geri çekilir?

Sıcak cüzdanınızdan herhangi bir adresi seçin, 1 USDT komisyon ödeyin ve gönderin.

Başlamak için mağazayı veya şirketi doğrulamam gerekiyor mu?

Şu anda gerekli değil. Gelecekte dünya çapındaki bazı yargı bölgelerinin buna ihtiyacı olabilir.

Ödeme başarısız olursa ödeme bağlantısını manuel olarak yeniden göndermek mümkün olacak mı?

Evet, ödeme bağlantısını herhangi bir messenger (veya posta yoluyla) aracılığıyla gönderebilirsiniz. Belirli bir cüzdana belirli bir miktar ödeme yaparken, ödeyenin bu bilgiyi nereden aldığına ve hatta ödemeyi hangi üçüncü taraf cüzdan aracılığıyla yaptığına bakılmaksızın, sipariş otomatik olarak ödendi durumunu alacaktır.

Sisteminiz müşteriye ödemeyle ilgili ayrı bir e-posta gönderiyor mu?

Şu anda e-posta gönderimi bulunmamaktadır. Müşterilerinizin e-postalarını saklamıyoruz. Ancak bir mektup göndermeyi planlıyoruz, ancak yine müşteri e-postalarını saklamayacağız.

Platformunuz herhangi bir bilgi saklıyor mu?

E-postanızı daha fazla açıklamaya gerek kalmadan ve çevrimiçi mağazanızın adresine bağlı kalmadan anonimleştirilmiş işlemlerin anonimleştirilmiş geçmişini saklar. Çevrimiçi mağazanızın adresini bile saklamıyoruz.

Sizin tarafınızda bilgileri takip eden herhangi bir izleyici var mı?

Bizim tarafımızdan herhangi bir takip cihazı, pazarlama çerezleri vb. bulunmamaktadır. AdGuard AdBlocker gururla 0 gösteriyor ve biz de bundan gurur duyuyoruz.

Platformunuz müşteri bilgilerini paylaşıyor mu?

Hayır ve bunu planlamıyoruz.

Eklentiniz hangi fiat para birimlerini destekliyor?

Yaklaşık 147 dünya para birimi, yani neredeyse tamamı. Dikkat USDT kuru her zaman tam olarak 1 dolar değildir. Bazen 0,999 veya 1,001 olur. Dolaylı olarak, bu diğer para birimleri için de geçerlidir, önce para biriminiz alınır, örneğin Norveç kronu, Norveç Ulusal Bankası kuru üzerinden ABD dolarına çevrilir ve ardından USD, ortalama kuru üzerinden USDT’ye dönüştürülür. izleyici (coingecko veya coinmarketcap).

Kendi kripto paramı sisteminize ekleyebilir miyim?

Şu anda, kripto para biriminiz Tron blok zincirinde ve TRC20 protokolü kapsamındaysa (03.09.2023, ayrıca ERC20 Ethereum ve BEP20 Binance Smart Chain token’larına da yeteneği eklendi), aşağıdaki olasılıklar vardır:

  1. Yalnızca mağazanız veya mağaza zinciriniz dahilinde (10-15’e kadar), kripto para biriminizi 1990 USDT karşılığında ekleyebiliriz, ödeme bağlantısı. Ödeme yapıldıktan sonra bize support@mitilena.com adresinden bir e-posta yazın, tam mağaza adreslerini ve tokenınızla ilgili bilgileri belirtin; biz de bu mağazalara API aracılığıyla paranızı ek olarak vereceğiz. Kullanıcılarınız size kendi kripto para biriminizle ödeme yapabilecektir. Oranı hem sabit kaynaklardan hem de açık kaynaklardan (coinmarketcap, coingecko) ayarlayabiliriz.
  2. Coinlerinizi tüm ağımıza eklemek istiyorsanız hisselerimizin en az %1’ine sahip olmanız gerekmektedir.

Blockchain’lerin geri kalanı yolda, bize blockchain’inizi ve onu nasıl uyguladığımızı içeren bir e-posta gönderirseniz size bilgi vereceğiz.

Ödeme sistemimiz günlük sorunsuz kullanıma odaklandığından stabilcoinleri tercih ediyoruz. Ancak yakın gelecekte Bitcoin ve diğer daha değişken para birimlerini kabul etmeyi planlıyoruz.

Bir şeyi açıklığa kavuşturmak istiyorsanız teknik desteğimize yazın. Dikkat, teknoloji. destek yalnızca Premium kullanıcılar için çalışır, premium kullanıcı olduğunuzda, işlemleri çevrimdışı imzalamak için uygulamayı indirme fırsatına ve diğer avantajlara sahip olacaksınız. Aylık 2$’dan başlayan maliyet. Ayrıca cüzdanınızın özel anahtarının yalnızca size ait olduğundan emin olmak için süper güvenli çevrimdışı özel anahtar oluşturma sistemimizi deneyin. Peki, özel anahtarınızı herhangi bir yere göndermeden, ancak bilgisayarınızda veya flash sürücünüzde saklayarak kripto para biriminizi kullanabileceğiniz cüzdanımız.

Geliştiriciler için API bağlantı talimatları

  1. Sistemimizde “Ayarlar” bölümünden bir API anahtarı almanız gerekir. Kayıt işlemi yaklaşık 5 saniye sürmektedir. Mağazanızın ilk incelemesi ve onayı gerekli değildir. Hemen kripto para kabul etmeye başlayabilir ve hemen çekebilirsiniz.
  2. Çevrimiçi mağazanızda sipariş verildiğinde ve siparişin toplam maliyeti sizin tarafınızdan hazır olduğunda, POST isteği ile sunucumuza göndereceğiniz bir JSON nesnesi oluşturursunuz.
  3. Olası ödeme talebinizi kaydediyoruz, yanıt olarak size dahili sipariş numaramızı ve ödeme bağlantısını gönderiyoruz.
  4. Kullanıcıyı bu ödeme sayfasına yönlendiriyorsunuz, ödeme yapıyor, otomatik olarak sitenize yönlendiriliyor.
  5. WGizli bir istekle sitenizle iletişime geçin ve siparişin ödendiğini söyleyin (bu, sözde web kancası aracılığıyla yapılır). Siparişi veritabanınıza ücretli (otomatik) olarak koyarsınız ve sonrasında süreç sizin için diğer ücretli siparişler gibi standart olur.

Çevrimiçi mağazanız WordPress (WooCommerce) tarafından destekleniyorsa, hiçbir şey programlamanıza gerek yoktur; kripto para birimini kabul etmek için hazır bir eklentimiz var, talimatlar ve eklentinin kendisi için bağlantıyı takip edin.

API’nin açıklaması:

Adım 2, bir JSON nesnesi oluşturma (JavaScript örneği). Blockchain alanı için olası değerler, değeri tırnaklardan alın (örneğin: tether-trc20):

'tether-erc20' (ERC20 Ethereum USDT, contract: 0xdac17f958d2ee523a2206206994597c13d831ec7)
'tether-bep20' (BEP20 Binance smart chain USDT, contract: 0x55d398326f99059ff775485246999027b3197955)
'tether-trc20' (TRC20 Tron USDT, contract: TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t)
'mitilena-own' (Vanishing Mitilena, VMT token)
'apfcoin' (ERC20 Ethereum APFC, contract: 0x8eD955a2b7d2C3a17a9d05dACa95E01818f8C11e)

 

let createPaymentObj =
    {
        userSecret: 'your_API_key', // required
        userPaymentId: 'your_payment_id_usually_order_id', // required
        blockchain: 'tether-trc20', // required 
        fiatCode: '3x_ISO_code_of_your_fiat_currency_for example_EUR', // required
        customerEmail: 'customer_mail', // required

        fiatAmount: 'digit_amount_in_fiat_currency_for_example_100', // number, required
        userProductId: 'your_product_id_if_any', // not required
        language: 'two_digit_ISO_language_code', // default en, not required [available: en, cz, ru, tr, my, hr, si, ar, swa] - the rest will be an error
        // redirectUrl_yours: 'thank_you_page or success_page',
        redirectUrl_yours: 'url_on_your_site_where_to_send_user_after_successful_payment', // not required, but very desirable
        webHookPostUrl_yours: 'url_on_your_site_where_the_hidden_POST_request_will_go_on_successful_payment,' // required
    }

İsteğin başlıklarına ayrıca API anahtarınızı da eklemeniz gerekir: ‘mitilena-signature’: ‘your_api_key’ Şuna benzer:

headers: {
     'Content-Type': 'application/json',
     accept: 'application/json',
     'mitilena-signature': 'your_key',
}

Ve bunu POST isteği olarak şu adrese gönderin: https://mitilena.com/api/generatePayment Faturanın oluşturulması başarılıysa, sunucunun yanıtı kodla birlikte olacaktır. 200 ve yanıt bir JSON nesnesi içerecektir; örneğin şunun gibi bir şey: Bu yanıttan yalnızca 2 alana ihtiyacınız vardır: invoiceId ve paymentPage. Kullanıcıyı Mitilena Pay web sitesinin ödeme sayfasına [ödeme Sayfası alanı] göndermeniz (yönlendirmeniz) gerekir!

{
  usdtOverAmount: '1.580437',
  invoiceId: 'auto-e80099-ef456c-e0de42',
  invoiceVs: '0437',
  fiatAmount: '1.450',
  fiatCurrency: 'EUR',
  rateLocalCurrencyToNeededCrypto: '0.917',
  rateNeededCryptoToUSD: '0.99959700',
  isTrc20: 1,
  isErc20: 0,
  isBep20: 0,
  whenInit: '2023-08-22T11:30:05.000Z',
  contractAddress: 'TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t',
  customerEmail: 'email_customer@email.com',
  productId: 85,
  expiresAt: '2023-09-05T11:30:05.000Z',
  blockchainHash: null,
  cryptoShortCode: 'USDT',
  cryptoValue: '1.580437',
  fiatValue: '1.450',
  receivedOnAddress: 'TRHpcBugcdEdD6BdW6k1Grtof6LBvRGWWJ',
  txId: 'auto-e80099-ef456c-e0de42',
  fiatShortCode: 'EUR',
  wasPaid: null,
  redirectUrl: 'https://google.com',
  paymentPage: 'https://mitilena.com/pay/auto-e80099-ef456c-e0de42/fast/'
}

Bir hata oluşursa, sunucunun yanıtı 400 kodlu olacaktır ve yanıt, hata metni olan bir String’i içerecektir. Böyle bir bağlantının ömrü 14 gündür. Bağlantının ömrünü seçmeyi mümkün kılacak planlar var.

JavaScript örnekleri (node.js sürüm 16.8) İstek:
const https = require('https');
const url = require('url');

const data = JSON.stringify({
    userSecret: '',
    userPaymentId: 'userPaymentdId111',
    blockchain: 'tether-trc20',
    fiatCode: 'EUR',
    customerEmail: 'email_customer@email.com',

    fiatAmount: 1.45,
    userProductId: 'new_someGoodsOk',
    language: 'en', // default en, not neccessary
    // redirectUrl_yours: 'https://google.com',
    redirectUrl_yours: 'https://google.com',
    webHookPostUrl_yours: 'https://mitilena.com/mi_webhook/'
});

const myURL = url.parse('https://mitilena.com/api/generatePayment');

const options = {
    hostname: myURL.hostname,
    port: myURL.port,
    path: myURL.pathname,
    method: 'POST',
    headers: {
        'Content-Type': 'application/json',
        accept: 'application/json',
        'mitilena-signature': '',
    },
};

requestAsync(options, data)
    .then(dataFObj => {
        if (dataFObj.statusCode === 200) {
            let tokensObj = JSON.parse(dataFObj.dataRaw);
            console.log('success:', tokensObj)
        } else {
            console.log('error dataFObj', dataFObj);
            throw new Error('some errror in postToWebHook ' + dataFObj.dataRaw);
        }
    })
    .catch(e => {
        console.log('error request:', e)
    })


function requestAsync(optionsArr, dataToPost = false) {
    return new Promise((resolve, reject) => {
        const req = https.request(optionsArr, (resp) => {
            // console.log(`statusCode: ${resp.statusCode}`);
            let dataF = '';
            // A chunk of data has been received.
            resp.on('data', (chunk) => {
                dataF += chunk;
            });

            resp.on('end', () => {
                resolve({statusCode: resp.statusCode, dataRaw: dataF});
            }).on('error', (err) => {
                console.log('Error: ' + err);
                reject(err);
            });
        });

        if (dataToPost) {
            req.write(dataToPost);
        }

        req.end();
    });
}

Node.js’nin 16. sürümündeki url modülü sözdizimini değiştirmiş gibi görünüyor, eğer varsa bu konuyla ilgili bilgi bulun veya adresi ve yolu manuel olarak girin.

PHP ve WordPress’teki örnekler: Bir WordPress işlevi wp_remote_post() kullanarak sorgulayın, saf PHP işlevine bakın, şuna benzer bir şeye benzeyecektir:
<?php
$request_body = [
    'userSecret' => $this->mitilenaToken,
    'userPaymentId' => $order->id,    
    'blockchain' => 'tether-trc20',
    'fiatCode' => $order->currency,    
    'customerEmail' => $order->get_billing_email(),

    'fiatAmount' => $order->get_total(),
    'userProductId' => $orderids,
    'language' => 'en', // default en, not neccessary
    'redirectUrl_yours' => $order->get_checkout_order_received_url(),
    'webHookPostUrl_yours' => 'https://mywebsite.com/post-handler.php'

];

$request_headers = [
    'content-type' => 'application/json',
    'mitilena-signature' => $this->mitilenaToken,
];

$args = [
    'method' => 'POST',
    'httpversion' => '1.0',
    'timeout' => 90,
    'headers' => $request_headers,
    'body' => ''
];

$environment_url = 'https://mitilena.com/api/generatePayment/';

$result = wp_remote_post($environment_url, array(
        'method' => 'POST',
        'headers' => $request_headers,
        'timeout' => 60, // added
        'redirection' => 5,  // added
        'blocking' => true, // added
        'httpversion' => '1.0',
        'sslverify' => false,
        'body' => json_encode($request_body))
);

$fullObj = json_decode($result['body']);

if (isset($result['response']) && isset($result['response']['code']) && $result['response']['code'] != 200) {
    $mi__err_message = 'Unknown error';
    if (isset($result['body'])) {
        $mi__err_message = 'Error: ' . $result['body'];
    }
    // error handling + exit
    exit;
}

if (!isset($fullObj->paymentPage)) {
    http_response_code(400); // Bad Request
    echo "Error: No payment page specified";
    exit;
}
$paymentPage = $fullObj->paymentPage;

if (strlen($paymentPage) < 5) {
    http_response_code(400); // Bad Request
    echo "Error: payment page is too short.";
    exit;
}
?>

 

5. Adım, sitenizin (sunucunun) yanında bir WebHook işleyicisi oluşturma:

Node.js 16.8 sürümü ve Express.js 4 sürümü (JavaScript) örneğinde
const bodyParser = require('body-parser');
const Big = require('big.js')
let endpointSecret = 'copy of the api key value'

// an object called statusObj arrives
app.post('/mi_webhook/', bodyParser.json(), (request, response) => {

    try {
        let eventObj = request.body;
        const signature = request.headers['mitilena-signature'];

        console.log({eventObj});
// compare the incoming secret key with your real one
        if (signature === endpointSecret) {
            if (!eventObj.statusObj) {
                return response.status(400).send('Error, no object.');
            }

            let hookObj = eventObj.statusObj;

            if (
                typeof hookObj.mitilenaInvoiceId === 'undefined' ||
                typeof hookObj.yourPaymentId === 'undefined' ||
                typeof hookObj.yourProductName === 'undefined' ||
                typeof hookObj.yourProductId === 'undefined' ||
                typeof hookObj.secretKey === 'undefined' ||
                typeof hookObj.stableCoinAmount === 'undefined' ||
                typeof hookObj.stableCoinSymbol === 'undefined' ||
                typeof hookObj.stableCoinBlockchain === 'undefined' ||
                typeof hookObj.localCurrencyAmount === 'undefined' ||
                typeof hookObj.localCurrencyCode === 'undefined' ||
                typeof hookObj.wasPaid === 'undefined' ||
                typeof hookObj.blockchainHash === 'undefined'
            ) {
                return response.status(400).send('Error, incomplete object.');
            }

            if (hookObj.wasPaid === true) {
                let centsAmount = Big(hookObj.localCurrencyAmount).times(Big(100)).round(0).toNumber();

// put the order in your database as paid and return the status code 200
// this is an example of our code, yours may look different
                paymentsModel
                    .completeUserPayment(hookObj.mitilenaInvoiceId, centsAmount)
                    .then((okString) => {
                        return response.status(200).send('all good Mitilena token');
                    })
                    .catch((e) => {
                        console.log('err in completeUserCardPayment', e.message);
                        return response.status(400).send('error, contact support');
                    });
            } else {
                return response.status(400).send('invoice was not paid');
            }
        } else {
            return response.status(400).send('bad Mitilena token');
        }
    } catch (e) {
        console.log('webhook err:', e.message);
        return response.status(400).send('bad request, error');
    }
});
PHP örneğini kullanarak:

Create a handler file and put it on your web server (site) so that it is accessible from the outside, i.e. if you write the full path to the file so that it opens, for example https://youwebsite.com/webhook.php (this is an example, you can do it differently, through routing, etc.). As mentioned above, specify this address in the object in which you create a payment link, i.e. {…. webHookPostUrl_yours: ‘https://youwebsite.com/webhook.php’ …} File contents:

<?php
$mi__jsonData = file_get_contents('php://input');
if (!$mi__jsonData) {
    http_response_code(400); // Bad Request
    echo 'bad input data';
    exit;
}
// Decode the JSON data into a PHP associative array
$mitilena_data = json_decode($mi__jsonData, true);


// Check if decoding was successful
if ($mitilena_data !== null && isset($mitilena_data['statusObj'])) {
    $mitilena_data = $mitilena_data['statusObj'];

    if (!isset($mitilena_data['secretKey'])) {
        http_response_code(400); // Bad Request
        echo "Error: Api key of Mitilena (Mitilena Token) is not specified. We can't verify if the request is genuine. Cancellation of a transaction.";
        exit;
    }
    $mitilenaToken = $mitilena_data['secretKey'];

    // compare your real API key with the one you received
    $realMitilenaToken = 'your_api_key'


    if ($mitilenaToken != $realMitilenaToken) {
        http_response_code(400); // Bad Request
        echo "Error: API token does not match. The website owner must specify the correct Api Mitilena token.";
        exit;
    }


    if (!isset($mitilena_data['yourPaymentId'])) {
        http_response_code(400); // Bad Request
        echo "Error: No payment id specified";
        exit;
    }
    $mi__paymentId = $mitilena_data['yourPaymentId'];

    if (strlen($mi__paymentId) < 1) {
        http_response_code(400); // Bad Request
        echo "Error: too short payment id.";
        exit;
    }
    
    function mi__pay_escapeString($var)
    {
        $var = stripslashes($var);
        $var = htmlentities($var);
        $var = strip_tags($var);
        return $var;
    }

    // yourPaymentId
    try {
        $mi__order = '';  // search your database for this order, mi__pay_escapeString($mi__paymentId)
    } catch (Throwable $e) {
        http_response_code(400); // Bad Request
        echo "Error: wrong payment id (order id). {yourPaymentId: \"\"}";
        exit;
    }

    if (!isset($mitilena_data['wasPaid'])) {
        http_response_code(400); // Bad Request
        echo "Error: No payment status specified";
        exit;
    }
    $mi__wasPaid = $mitilena_data['wasPaid'];


    if ($mi__wasPaid == true) {

        $blockchainHash = '';
        if (isset($mitilena_data['blockchainHash'])) {
            $blockchainHash = mi__pay_escapeString($mitilena_data['blockchainHash']);
        }

        // set the order as paid in your database
        // reduce inventory if required
        // send the user an email if required

        echo 'success';
    } else {
        echo 'unpaid status received';
    }
 } else {

    // JSON decoding failed
    http_response_code(400); // Bad Request
    echo "Invalid JSON data";
}

exit;
?>

Hepsi bu, herhangi bir sorunuz varsa yorumlarda sorun. Bunu sizin için uygulayacak bir geliştiriciniz yok mu? Bize support@mitilena.com adresinden yazın; geliştiricinin kripto ödemelerini bağlama konusundaki çalışması için size ticari bir teklif sunacağız.

Bir yanıt yazın

E-posta adresiniz yayınlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir