LAMP для WordPress на FreeBSD 10 через pkg add

1) Устанавливаем apache

pkg install apache24

, правим /usr/local/etc/apache24/httpd.conf, присвоив ServerName и ServerAdmin. Стартуем

service apache24 start

, разрешаем запуск после перезагрузки

sysrc apache24_enable=yes

2) Ставим Mysql

pkg install mysql57-server
sysrc mysql_enable=yes
service mysql-server start

И поменяем пароль на вход для root

mysql_secure_installation

3) Ставим PHP

pkg install mod_php71 php71-mysqli

Для того чтобы Apache24 знал что делать с файлами php, редактируем https.conf

<IfModule dir_module>
    <FilesMatch «\.php$»>
        SetHandler application/xhttpdphp
    </FilesMatch>
    <FilesMatch «\.phps$»>
        SetHandler application/xhttpdphpsource
    </FilesMatch>
</IfModule>

Ставим дополнительные модули PHP для работы WordPress

pkg install php71-zip php71-openssl php71-mbstring php71-mysqli php71-mcrypt php71-json php71-iconv php71-gd php71-curl php71-dom php71-curl

4) Создаем пользователя для доступа по SSH

adduser

Читаем печеньки (coockies) из webview, android

Прочитать cookies на открытой странице в webview можно например так:

public String CookieExtract (String cooks,String coocksname){
        String CookieValue = null;
        if (cooks!=null) {
            Log.v("Form1", "Все куки:"+cooks);
            Log.v("Form1", "Ищем:"+coocksname);
            String[] temp = cooks.split(";");
            for (String ar1 : temp) {
                if (ar1.contains(coocksname)) {
                    String[] temp1 = ar1.split("=");
                    CookieValue = temp1[1];
                    break;
                }
            }
        } else {
            Log.v("Form1", "Куков пока нет...");
        };
        return CookieValue;
    };
    @Override
    public void onPageFinished(WebView view, String url){
        user_randomid_w3=CookieExtract(CookieManager.getInstance().getCookie(url),"user_randomid_w3");
        Log.v("Form1", "Прочитали куки:"+user_randomid_w3);
        mbrowser.setVisibility(View.VISIBLE);
        spiner.setVisibility(View.INVISIBLE);
        super.onPageFinished(view, url);

    }

Напоминалки по не всегда очевидным вещам при написании кода для Android

1) Скрыть меню приложения

        ActionBar actionBar = getSupportActionBar();
        if (actionBar != null) {
            actionBar.show();
        };

2) Скрыть таскбар (сделать приложение в полный экран)

    public  void hideall(){
        if (Build.VERSION.SDK_INT < 16) {
            getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
        } else {
            View decorView = getWindow().getDecorView();
            int uiOptions = View.SYSTEM_UI_FLAG_FULLSCREEN;
            decorView.setSystemUiVisibility(uiOptions);
            ActionBar actionBar = getSupportActionBar();
            if (actionBar != null) {
                actionBar.hide();
            };
        };
    };

3) Запретить кнопку «Назад»

    @Override
    public void onBackPressed() {
        super.onResume();
    }

4) Проверка наличия интернет на устройстве

    public boolean isOnline() {
       ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
       return cm.getActiveNetworkInfo() != null && cm.getActiveNetworkInfo().isConnectedOrConnecting();
     }

5) Вывод в webView картинки и сообщения «офлайн»

            String htmlString ="<html><body><table border=0><tr><td><img src='oi.png'></td><td>Интернет кончился..</td></tr></table></body></html>";
            mbrowser.loadDataWithBaseURL("file:///android_res/drawable/", htmlString, "text/html", "UTF-8", null);

6) Обработка «самоподписанного» сертификата SSL в webView

    @Override
    public void onReceivedSslError(WebView view, final SslErrorHandler handler, SslError error) {
        final AlertDialog.Builder builder = new AlertDialog.Builder(Form1.this);
        builder.setMessage(R.string.notification_error_ssl_cert_invalid);
        builder.setPositiveButton("Доверяем ему", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                handler.proceed();
            }
        });
        builder.setNegativeButton("Уходим", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                handler.cancel();
            }
        });
        final AlertDialog dialog = builder.create();
        dialog.show();
        hideall();
    }

7) Обработка выбора сертификата p12 в webView

    @Override
    public void onReceivedClientCertRequest(WebView view, final ClientCertRequest request) {
        Log.v(getClass().getSimpleName(), "===> certificate required!");

        KeyChain.choosePrivateKeyAlias(Form1.this, new KeyChainAliasCallback(){
            @TargetApi(Build.VERSION_CODES.LOLLIPOP)
            @Override
            public void alias(String alias) {
                Log.v(getClass().getSimpleName(), "===>Key alias is: " + alias);
                try {
                    PrivateKey changPrivateKey = KeyChain.getPrivateKey(Form1.this, alias);
                    X509Certificate[] certificates = KeyChain.getCertificateChain(Form1.this, alias);
                    Log.v(getClass().getSimpleName(), "===>Getting Private Key Success!" );
                    request.proceed(changPrivateKey, certificates);
                } catch (KeyChainException e) {
                    Log.e(getClass().getSimpleName(), Util.printException(e));
                } catch (InterruptedException e) {
                    Log.e(getClass().getSimpleName(), Util.printException(e));
                }
            }
        },new String[]{"RSA"}, null, null, -1, null);
    }

Странное поведение документа ОплатаОтПокупателейПлатежнойКартой в 1С Розница 2.2

Если документ проведен, то денежки идут на регистры «Расчеты с контрагентами» и «Продажи по платежным картам», вне зависимости от того, прошла оплата по карточке или нет. Т.е. например типичная ситуация:

Создали документ «Эквайринговая операция», провели его, попробовали оплатить с карты — не прошло. Клиенту «ну тогда платите наличкой». Документ закрыли, но 1С по регистрам будет считать, что деньги то поступили не в кассу! Хотя по факту вообще они могут никуда не поступить.

И в отчете «Продажи по платежным картам» мы тоже ничего не увидим!! Дурдом.

Единственный вариант — писать свой отчет по продажам, в котором проверять на true поле «Оплата прошла».

 

Жизнь замечательных грибов