apt-cache search server | grep -i http
<html><body>
<form action="index.php" method="post">
<div><label>Введите данные: </label> <input type="text" name="inn" /></label></div>
<div><button type="submit" value="Ok" /></div>
</form>
<?php
include 'function.php'; // Подключаем файл с нашей функцией
if (!empty($_POST) && isset($_POST['inn'])) {
echo 'Результат:' . parse_inn($_POST['inn']);
}
?>
</body></html>
<html>
<head>
<title>Online PHP Script Execution</title>
</head>
<body>
<?php
function parse_inn($inn){
//$id must contain 10 digits
if (empty($inn) || !preg_match('/^\d{10}$/',$inn)) return false;
$months = array('января', 'февраля', 'марта', 'апреля', 'мая', 'июня', 'июля', 'августа', 'сентября', 'октября', 'ноября', 'декабря');
$result = array();
$result['inn'] = $inn;
$result['sex'] = (substr($inn, 8, 1) % 2) ? 'm' : 'f';
$split = str_split($inn);
$summ = $split[0]*(-1) + $split[1]*5 + $split[2]*7 + $split[3]*9 + $split[4]*4 + $split[5]*6 + $split[6]*10 + $split[7]*5 + $split[8]*7;
$result['control'] = (int)($summ - (11 * (int)($summ/11)));
$result['status'] = ($result['control'] == (int)$split[9]) ? true : false;
$inn = substr($inn, 0, 5);
$normal_date = date('d.m.Y', strtotime('01/01/1900 + ' . $inn . ' days - 1 days'));
list($result['day'], $result['month'], $result['year']) = explode('.', $normal_date);
$result['str_month'] = $months[$result['month'] - 1];
return $result;
}
$var = 10;
var_dump($var, parse_inn($var));
?>
</body>
</html>
/*
* jQuery Boilerplate - v3.3.4
* A jump-start for jQuery plugins development.
* http://jqueryboilerplate.com
*
* Made by Zeno Rocha
* Under MIT License
*/
// the semi-colon before function invocation is a safety net against concatenated
// scripts and/or other plugins which may not be closed properly.
;(function ( $, window, document, undefined ) {
// undefined is used here as the undefined global variable in ECMAScript 3 is
// mutable (ie. it can be changed by someone else). undefined isn't really being
// passed in so we can ensure the value of it is truly undefined. In ES5, undefined
// can no longer be modified.
// window and document are passed through as local variable rather than global
// as this (slightly) quickens the resolution process and can be more efficiently
// minified (especially when both are regularly referenced in your plugin).
// Create the defaults once
var pluginName = "defaultPluginName",
defaults = {
propertyName: "value"
};
// The actual plugin constructor
function Plugin ( element, options ) {
this.element = element;
// jQuery has an extend method which merges the contents of two or
// more objects, storing the result in the first object. The first object
// is generally empty as we don't want to alter the default options for
// future instances of the plugin
this.settings = $.extend( {}, defaults, options );
this._defaults = defaults;
this._name = pluginName;
this.init();
}
// Avoid Plugin.prototype conflicts
$.extend(Plugin.prototype, {
init: function () {
// Place initialization logic here
// You already have access to the DOM element and
// the options via the instance, e.g. this.element
// and this.settings
// you can add more functions like the one below and
// call them like so: this.yourOtherFunction(this.element, this.settings).
console.log("xD");
},
yourOtherFunction: function () {
// some logic
}
});
// A really lightweight plugin wrapper around the constructor,
// preventing against multiple instantiations
$.fn[ pluginName ] = function ( options ) {
this.each(function() {
if ( !$.data( this, "plugin_" + pluginName ) ) {
$.data( this, "plugin_" + pluginName, new Plugin( this, options ) );
}
});
// chain jQuery functions
return this;
};
})( jQuery, window, document );
(function ($){
"use strict";
function myFunction(items){
return $(items).each(function(){
$(this).text("Hello, jQuery!");
});
}
$.fn.hellojQuery = myFunction;
}(jQuery));