shaba
Version:
JavaScript utilities to validate Iranian bank cards and IBAN (Sheba) codes, convert Persian numerals, and detect bank info.
309 lines (279 loc) • 16.6 kB
HTML
<html lang="fa" dir="rtl">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>SHABA</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.rtl.min.css" rel="stylesheet">
<style>
body {
font-family: "Vazir", sans-serif;
background-color: #f9f9f9;
}
input {
direction: ltr;
text-align: center;
font-family: monospace;
}
img.bank-logo {
width: 48px;
height: 48px;
object-fit: contain;
border: 1px solid #ccc;
border-radius: 8px;
background-color: white;
}
pre {
background-color: #f1f1f1;
padding: 1rem;
overflow-x: auto;
}
section {
background: #fff;
padding: 2rem;
border-radius: 10px;
margin-top: 2rem;
box-shadow: 0 0 10px rgba(0,0,0,0.05);
}
table {
width: 100%;
border-collapse: collapse;
margin: 20px 0;
}
th, td {
border: 1px solid #ddd;
padding: 8px 12px;
text-align: right;
}
th {
background-color: #f8f9fa;
}
tr:nth-child(even) {
background-color: #f9f9f9;
}
.regex {
font-family: monospace;
background-color: #f0f0f0;
padding: 2px 5px;
border-radius: 3px;
direction: ltr;
display: inline-block;
}
table tr td:last-child {
direction: ltr;
text-align: left;
font-family: monospace;
unicode-bidi: isolate; /* Ensures proper rendering */
}
</style>
</head>
<body class="container py-5">
<h1 class="text-center mb-5">🟢 SHABA</h1>
<p class="text-center">توجه: تلفظ صحیح شبا به صورت (SHEBA) میباشد.</p>
<hr/>
<div class="row g-4 mt-4 mb-4">
<h2>پیشنمایش</h2>
<!-- Card Input -->
<div class="col-md-6">
<label for="cardInput" class="form-label">شماره کارت بانکی</label>
<input id="cardInput" type="text" class="form-control" placeholder="مثال: ۶۰۳۷۹۹۱۲۳۴۵۶۷۸۹۰">
</div>
<div class="col-md-1 d-flex align-items-end">
<img id="cardBankLogo" src="./bank-iran/no-img.png" class="bank-logo" alt="Bank Logo"><span id="cardName"></span>
</div>
<!-- Shaba Input -->
<div class="col-md-6">
<label for="shabaInput" class="form-label">شماره شبا (IBAN)</label>
<input id="shabaInput" type="text" class="form-control" placeholder="مثال: 620190000000100324200001">
</div>
<div class="col-md-1 d-flex align-items-end">
<img id="shabaBankLogo" src="./bank-iran/no-img.png" class="bank-logo" alt="Bank Logo"><span id="shabaName"></span>
</div>
</div>
<hr/>
<!-- Documentation -->
<section class="mt-4">
<h2>راهنمای استفاده از شبا</h2>
<p>
اعتبار سنجی و تشخیص (به همراه تصویر) شماره کارت و شماره شبا بانک
</p>
<br/><br/>
<h3>📦 نصب</h3>
<p><strong>CDN:</strong></p>
<pre dir="ltr"><code><script src="https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/dist/shaba.min.js"></script></code></pre>
<p><strong>NPM:</strong></p>
<pre dir="ltr"><code>npm install shaba</code></pre>
<br/><br/>
<h3>🧪 مثال استفاده</h3>
<pre dir="ltr"><code>
const card = shaba.convertPersianToEnglishDigits('۶۰۳۷۹۹...');
const isValid = shaba.validateCard(card);
const prefix = card.slice(0, 6);
const bank = shaba.getBankFromCard(prefix);
console.log(bank); // ["meli", "603799", "بانک ملی"]
</code></pre>
<br/><br/>
<h3>🧠 توابع در دسترس</h3>
<ul>
<li><code>convertPersianToEnglishDigits(str)</code> — تبدیل ارقام فارسی/عربی به انگلیسی</li>
<li><code>validateCard(cardNumber)</code> — بررسی اعتبار شماره کارت</li>
<li><code>getBankFromCard(prefix)</code> — دریافت اطلاعات بانک از روی شماره کارت</li>
<li><code>getBankFromShaba(code)</code> — دریافت بانک از کد شبا</li>
</ul>
<br/><br/>
<h3>🖼 استفاده از لوگوهای بانکی</h3>
<pre dir="ltr"><code><img src="https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/bank-iran/meli ... .png"></code></pre>
<br/><br/>
<h3>🧪 نمونه کد</h3>
<pre dir="ltr"><code dir="ltr"><!-- نمایش لوگوی بانک کارت -->
<img width="32px" id="cardBankLogo" src="https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/bank-iran/no-img.png">
<!-- ورودی شماره کارت (سمت چپ به راست برای اعداد) -->
<input type="text" id="cardInput" class="creditcart-input" style="direction:ltr" placeholder="شماره کارت را وارد کنید">
<!-- نمایش لوگوی بانک شبا -->
<img width="32px" id="shabaBankLogo" src="https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/bank-iran/no-img.png">
<!-- ورودی شماره شبا -->
<input type="text" id="shabaInput" class="shaba-input" style="direction:ltr" placeholder="کد شبا را وارد کنید">
<!-- بارگذاری فایل جاوااسکریپت از CDN jsDelivr -->
<script src="https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/dist/shaba.min.js"></script>
<script type="text/javascript">
// دریافت المانهای ورودی از صفحه
const $card = document.getElementById('cardInput');
const $shaba = document.getElementById('shabaInput');
// وقتی شماره کارت تغییر کرد:
$card.addEventListener('input', function () {
const card = shaba.convertPersianToEnglishDigits(this.value); // تبدیل اعداد فارسی به انگلیسی
const isValid = shaba.validateCard(card); // بررسی اعتبار شماره کارت
const prefix = card.slice(0, 6); // گرفتن ۶ رقم اول کارت برای شناسایی بانک
const bank = shaba.getBankFromCard(prefix); // گرفتن اطلاعات بانک
// نمایش لوگوی بانک
document.getElementById('cardBankLogo').src =
"https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/bank-iran/" + bank[0] + ".png";
// رنگ کادر را بر اساس اعتبار تنظیم کن
this.style.borderColor = isValid ? 'green' : 'red';
});
// وقتی شبا تغییر کرد:
$shaba.addEventListener('input', function () {
const input = shaba.convertPersianToEnglishDigits(this.value.toUpperCase().replace(/-/g, ''));
const code = input.slice(2, 5); // استخراج کد بانک از شبا
const bank = shaba.getBankFromShaba(code); // گرفتن اطلاعات بانک
// نمایش لوگوی بانک مربوط به شبا
document.getElementById('shabaBankLogo').src =
"https://cdn.jsdelivr.net/gh/smohamadabedy/shaba@latest/bank-iran/" + bank[0] + ".png";
// بررسی صحت شماره شبا (Mod97)
const prepared = shaba.iso13616Prepare(input);
const valid = shaba.iso7064Mod97_10(prepared) === 1;
// رنگ کادر را بر اساس اعتبار تنظیم کن
this.style.borderColor = valid ? 'green' : 'red';
});
</script>
</code></pre>
<hr/>
<h2>دستورالعمل تشخیص بانک از طریق شماره شبا</h2>
<table>
<thead>
<tr>
<th>ردیف</th>
<th>نام بانک</th>
<th>شناسه بانک</th>
<th>الگوی رجکس</th>
</tr>
</thead>
<tbody>
<tr><td>1</td><td>بانک مرکزی جمهوری اسلامی ایران</td><td>010</td><td><span class="regex">/\d{2}(010)\d+/g</span></td></tr>
<tr><td>2</td><td>بانک صنعت و معدن</td><td>011</td><td><span class="regex">/\d{2}(011)\d+/g</span></td></tr>
<tr><td>3</td><td>بانک ملت</td><td>012</td><td><span class="regex">/\d{2}(012)\d+/g</span></td></tr>
<tr><td>4</td><td>بانک رفاه</td><td>013</td><td><span class="regex">/\d{2}(013)\d+/g</span></td></tr>
<tr><td>5</td><td>بانک مسکن</td><td>014</td><td><span class="regex">/\d{2}(014)\d+/g</span></td></tr>
<tr><td>6</td><td>بانک سپه</td><td>015</td><td><span class="regex">/\d{2}(015)\d+/g</span></td></tr>
<tr><td>7</td><td>بانک کشاورزی</td><td>016</td><td><span class="regex">/\d{2}(016)\d+/g</span></td></tr>
<tr><td>8</td><td>بانک ملی ایران</td><td>017</td><td><span class="regex">/\d{2}(017)\d+/g</span></td></tr>
<tr><td>9</td><td>بانک تجارت</td><td>018</td><td><span class="regex">/\d{2}(018)\d+/g</span></td></tr>
<tr><td>10</td><td>بانک صادرات ایران</td><td>019</td><td><span class="regex">/\d{2}(019)\d+/g</span></td></tr>
<tr><td>11</td><td>بانک توسعه صادرات</td><td>020</td><td><span class="regex">/\d{2}(020)\d+/g</span></td></tr>
<tr><td>12</td><td>پست بانک ایران</td><td>021</td><td><span class="regex">/\d{2}(021)\d+/g</span></td></tr>
<tr><td>13</td><td>بانک توسعه تعاون</td><td>022</td><td><span class="regex">/\d{2}(022)\d+/g</span></td></tr>
<tr><td>14</td><td>موسسه اعتباری توسعه</td><td>051</td><td><span class="regex">/\d{2}(051)\d+/g</span></td></tr>
<tr><td>15</td><td>بانک کارآفرین</td><td>053</td><td><span class="regex">/\d{2}(053)\d+/g</span></td></tr>
<tr><td>16</td><td>بانک پارسیان</td><td>054</td><td><span class="regex">/\d{2}(054)\d+/g</span></td></tr>
<tr><td>17</td><td>بانک اقتصاد نوین</td><td>055</td><td><span class="regex">/\d{2}(055)\d+/g</span></td></tr>
<tr><td>18</td><td>بانک سامان</td><td>056</td><td><span class="regex">/\d{2}(056)\d+/g</span></td></tr>
<tr><td>19</td><td>بانک پاسارگاد</td><td>057</td><td><span class="regex">/\d{2}(057)\d+/g</span></td></tr>
<tr><td>20</td><td>بانک سرمایه</td><td>058</td><td><span class="regex">/\d{2}(058)\d+/g</span></td></tr>
<tr><td>21</td><td>بانک سینا</td><td>059</td><td><span class="regex">/\d{2}(059)\d+/g</span></td></tr>
<tr><td>22</td><td>قرض الحسنه مهر</td><td>060</td><td><span class="regex">/\d{2}(060)\d+/g</span></td></tr>
<tr><td>23</td><td>بانک شهر</td><td>061</td><td><span class="regex">/\d{2}(061)\d+/g</span></td></tr>
<tr><td>24</td><td>بانک تات</td><td>062</td><td><span class="regex">/\d{2}(062)\d+/g</span></td></tr>
<tr><td>25</td><td>بانک انصار</td><td>063</td><td><span class="regex">/\d{2}(063)\d+/g</span></td></tr>
<tr><td>26</td><td>بانک گردشگری</td><td>064</td><td><span class="regex">/\d{2}(064)\d+/g</span></td></tr>
<tr><td>27</td><td>بانک حکمت ایرانیان</td><td>065</td><td><span class="regex">/\d{2}(065)\d+/g</span></td></tr>
<tr><td>28</td><td>بانک دی</td><td>066</td><td><span class="regex">/\d{2}(066)\d+/g</span></td></tr>
<tr><td>29</td><td>بانک ایران زمین</td><td>069</td><td><span class="regex">/\d{2}(069)\d+/g</span></td></tr>
</tbody>
</table>
<hr/>
<h2>دستورالعمل تشخیص بانک از شماره کارت</h2>
<table>
<thead>
<tr>
<th>نام بانک</th>
<th>پیش شماره</th>
<th>الگوی رجکس</th>
</tr>
</thead>
<tbody>
<tr><td>بانک ملی</td><td>۶۰۳۷۹۹</td><td><span class="regex">/(603799)\d+/g</span></td></tr>
<tr><td>بانک سامان</td><td>۶۲۱۹۸۶</td><td><span class="regex">/(621986)\d+/g</span></td></tr>
<tr><td>بانک سپه</td><td>۵۸۹۲۱۰</td><td><span class="regex">/(589210)\d+/g</span></td></tr>
<tr><td>بانک سینا</td><td>۶۳۹۳۴۶</td><td><span class="regex">/(639346)\d+/g</span></td></tr>
<tr><td>بانک توسعه صادرات</td><td>۶۲۷۶۴۸</td><td><span class="regex">/(627648)\d+/g</span></td></tr>
<tr><td>بانک سرمایه</td><td>۶۳۹۶۰۷</td><td><span class="regex">/(639607)\d+/g</span></td></tr>
<tr><td>بانک صنعت و معدن</td><td>۶۲۷۹۶۱</td><td><span class="regex">/(627961)\d+/g</span></td></tr>
<tr><td>بانک شهر</td><td>۵۰۴۷۰۶</td><td><span class="regex">/(504706)\d+/g</span></td></tr>
<tr><td>بانک کشاورزی</td><td>۶۰۳۷۷۰</td><td><span class="regex">/(603770)\d+/g</span></td></tr>
<tr><td>بانک دی</td><td>۵۰۲۹۳۸</td><td><span class="regex">/(502938)\d+/g</span></td></tr>
<tr><td>بانک مسکن</td><td>۶۲۸۰۲۳</td><td><span class="regex">/(628023)\d+/g</span></td></tr>
<tr><td>بانک صادرات</td><td>۶۰۳۷۶۹</td><td><span class="regex">/(603769)\d+/g</span></td></tr>
<tr><td>پست بانک</td><td>۶۲۷۷۶۰</td><td><span class="regex">/(627760)\d+/g</span></td></tr>
<tr><td>بانک ملت</td><td>۶۱۰۴۳۳</td><td><span class="regex">/(610433)\d+/g</span></td></tr>
<tr><td>بانک توسعه تعاون</td><td>۵۰۲۹۰۸</td><td><span class="regex">/(502908)\d+/g</span></td></tr>
<tr><td>بانک تجارت</td><td>۶۲۷۳۵۳</td><td><span class="regex">/(627383)\d+/g</span></td></tr>
<tr><td>بانک اقتصاد نوین</td><td>۶۲۷۴۱۲</td><td><span class="regex">/(627412)\d+/g</span></td></tr>
<tr><td>بانک رفاه</td><td>۵۸۹۴۶۳</td><td><span class="regex">/(589463)\d+/g</span></td></tr>
<tr><td>بانک پارسیان</td><td>۶۲۲۱۰۶</td><td><span class="regex">/(622106)\d+/g</span></td></tr>
<tr><td>موسسه نور</td><td>۵۰۷۶۷۷</td><td><span class="regex">/(507677)\d+/g</span></td></tr>
<tr><td>بانک پاسارگاد</td><td>۵۰۲۲۲۹</td><td><span class="regex">/(502229)\d+/g</span></td></tr>
<tr><td>موسسه ملل</td><td>۶۰۶۲۵۶</td><td><span class="regex">/(606256)\d+/g</span></td></tr>
<tr><td>بانک قوامین</td><td>۶۳۹۵۹۹</td><td><span class="regex">/(639599)\d+/g</span></td></tr>
<tr><td>بانک قرض الحسنه مهر ایرانیان</td><td>۶۰۶۳۷۳</td><td><span class="regex">/(606373)\d+/g</span></td></tr>
<tr><td>بانک کارآفرین</td><td>۶۲۷۴۸۸</td><td><span class="regex">/(627488)\d+/g</span></td></tr>
<tr><td>بانک گردشگری</td><td>۵۰۵۴۱۶</td><td><span class="regex">/(505416)\d+/g</span></td></tr>
</tbody>
</table>
</section>
<!-- Script -->
<script src="src/shaba.js"></script>
<script>
const $card = document.getElementById('cardInput');
const $shaba = document.getElementById('shabaInput');
$card.addEventListener('input', function () {
const card = shaba.convertPersianToEnglishDigits(this.value);
const isValid = shaba.validateCard(card);
const prefix = card.slice(0, 6);
const bank = shaba.getBankFromCard(prefix);
document.getElementById('cardBankLogo').src = "./bank-iran/" + bank[0] + ".png";
document.getElementById('cardName').innerHTML = bank[2];
this.style.borderColor = isValid ? 'green' : 'red';
});
$shaba.addEventListener('input', function () {
const input = shaba.convertPersianToEnglishDigits(this.value.toUpperCase().replace(/-/g, ''));
const code = input.slice(2, 5);
const bank = shaba.getBankFromShaba(code);
document.getElementById('shabaBankLogo').src = "./bank-iran/" + bank[0] + ".png";
document.getElementById('shabaName').innerHTML = bank[1];
const prepared = shaba.iso13616Prepare(input);
const valid = shaba.iso7064Mod97_10(prepared) === 1;
this.style.borderColor = valid ? 'green' : 'red';
});
</script>
</body>
</html>